From 39db6910e9c4a9ae26df47b56a84d165e6556d40 Mon Sep 17 00:00:00 2001 From: "Grant.Firl" Date: Tue, 4 Jun 2019 18:30:10 -0600 Subject: [PATCH 1/9] set NCEPLIBS_DIR environment variable for all Theia setup scripts and one Cheyenne setup script (need NCEPlibs installation that corresponds to other Cheyenne setup scripts --- scm/etc/Cheyenne_setup_pgi.csh | 4 ++++ scm/etc/Cheyenne_setup_pgi.sh | 4 ++++ scm/etc/Theia_setup_gnu.csh | 4 ++++ scm/etc/Theia_setup_gnu.sh | 4 ++++ scm/etc/Theia_setup_intel.csh | 4 ++++ scm/etc/Theia_setup_intel.sh | 4 ++++ scm/etc/Theia_setup_pgi.csh | 4 ++++ scm/etc/Theia_setup_pgi.sh | 4 ++++ 8 files changed, 32 insertions(+) diff --git a/scm/etc/Cheyenne_setup_pgi.csh b/scm/etc/Cheyenne_setup_pgi.csh index 085da0176..9658aa2fb 100755 --- a/scm/etc/Cheyenne_setup_pgi.csh +++ b/scm/etc/Cheyenne_setup_pgi.csh @@ -15,6 +15,10 @@ setenv CC pgcc setenv CXX pgc++ setenv FC pgf90 +echo "Setting NCEPLIBS_DIR environment variable" +set NCEPLIBS_DIR /glade/p/ral/jntp/GMTB/tools/NCEPlibs/20190307/pgi-17.9/mpt-2.19 +setenv NCEPLIBS_DIR ${NCEPLIBS_DIR} + #install f90nml for the local user #check to see if f90nml is installed locally diff --git a/scm/etc/Cheyenne_setup_pgi.sh b/scm/etc/Cheyenne_setup_pgi.sh index 66647f8cd..bb87ee224 100755 --- a/scm/etc/Cheyenne_setup_pgi.sh +++ b/scm/etc/Cheyenne_setup_pgi.sh @@ -15,6 +15,10 @@ export CC=pgcc export CXX=pgc++ export FC=pgf90 +echo "Setting NCEPLIBS_DIR environment variable" +NCEPLIBS_DIR=/glade/p/ral/jntp/GMTB/tools/NCEPlibs/20190307/pgi-17.9/mpt-2.19 +export NCEPLIBS_DIR=$NCEPLIBS_DIR + #install f90nml for the local user #check to see if f90nml is installed locally diff --git a/scm/etc/Theia_setup_gnu.csh b/scm/etc/Theia_setup_gnu.csh index 2fbcde175..74179b1e0 100755 --- a/scm/etc/Theia_setup_gnu.csh +++ b/scm/etc/Theia_setup_gnu.csh @@ -26,6 +26,10 @@ setenv CC gcc setenv CXX g++ setenv FC gfortran +echo "Setting NCEPLIBS_DIR environment variable" +set NCEPLIBS_DIR /scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-gnu-20181105 +setenv NCEPLIBS_DIR ${NCEPLIBS_DIR} + #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" echo $PATH | grep '/contrib/ananconda/2.3.0/bin$' >&/dev/null diff --git a/scm/etc/Theia_setup_gnu.sh b/scm/etc/Theia_setup_gnu.sh index b21aa0e2b..cc898ca1c 100755 --- a/scm/etc/Theia_setup_gnu.sh +++ b/scm/etc/Theia_setup_gnu.sh @@ -17,6 +17,10 @@ export CC=gcc export CXX=g++ export FC=gfortran +echo "Setting NCEPLIBS_DIR environment variable" +NCEPLIBS_DIR=/scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-gnu-20181105 +export NCEPLIBS_DIR=$NCEPLIBS_DIR + #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" echo $PATH | grep '/contrib/ananconda/2.3.0/bin$' >&/dev/null diff --git a/scm/etc/Theia_setup_intel.csh b/scm/etc/Theia_setup_intel.csh index e56150fd6..e9ab5ba46 100755 --- a/scm/etc/Theia_setup_intel.csh +++ b/scm/etc/Theia_setup_intel.csh @@ -13,6 +13,10 @@ setenv CC icc setenv CXX icpc setenv FC ifort +echo "Setting NCEPLIBS_DIR environment variable" +set NCEPLIBS_DIR /scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-intel-18.1.163-20181105 +setenv NCEPLIBS_DIR ${NCEPLIBS_DIR} + #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" echo $PATH | grep '/contrib/ananconda/2.3.0/bin$' >&/dev/null diff --git a/scm/etc/Theia_setup_intel.sh b/scm/etc/Theia_setup_intel.sh index a014760dc..d0d72dbad 100755 --- a/scm/etc/Theia_setup_intel.sh +++ b/scm/etc/Theia_setup_intel.sh @@ -13,6 +13,10 @@ export CC=icc export CXX=icpc export FC=ifort +echo "Setting NCEPLIBS_DIR environment variable" +NCEPLIBS_DIR=/scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-intel-18.1.163-20181105 +export NCEPLIBS_DIR=$NCEPLIBS_DIR + #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" echo $PATH | grep '/contrib/ananconda/2.3.0/bin$' >&/dev/null diff --git a/scm/etc/Theia_setup_pgi.csh b/scm/etc/Theia_setup_pgi.csh index c05df1828..ead9a1a3c 100755 --- a/scm/etc/Theia_setup_pgi.csh +++ b/scm/etc/Theia_setup_pgi.csh @@ -13,6 +13,10 @@ setenv CC pgcc setenv CXX pgc++ setenv FC pgf90 +echo "Setting NCEPLIBS_DIR environment variable" +set NCEPLIBS_DIR /scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-pgi-20181105 +setenv NCEPLIBS_DIR ${NCEPLIBS_DIR} + #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" echo $PATH | grep '/contrib/ananconda/2.3.0/bin$' >&/dev/null diff --git a/scm/etc/Theia_setup_pgi.sh b/scm/etc/Theia_setup_pgi.sh index 2c025a773..a9303d877 100755 --- a/scm/etc/Theia_setup_pgi.sh +++ b/scm/etc/Theia_setup_pgi.sh @@ -13,6 +13,10 @@ export CC=pgcc export CXX=pgc++ export FC=pgf90 +echo "Setting NCEPLIBS_DIR environment variable" +NCEPLIBS_DIR=/scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-pgi-20181105 +export NCEPLIBS_DIR=$NCEPLIBS_DIR + #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" echo $PATH | grep '/contrib/ananconda/2.3.0/bin$' >&/dev/null From 05ba70eda92f697ea1eaa4802d63c390e423b0d2 Mon Sep 17 00:00:00 2001 From: "Grant.Firl" Date: Tue, 4 Jun 2019 18:33:39 -0600 Subject: [PATCH 2/9] edit CMakeLists.txt to read in NCEPLIBS_DIR environment variable or apply a default, set variables for needed NCEPlibs, set STATIC to false --- scm/src/CMakeLists.txt | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/scm/src/CMakeLists.txt b/scm/src/CMakeLists.txt index f7e8cc97d..6a99672a6 100644 --- a/scm/src/CMakeLists.txt +++ b/scm/src/CMakeLists.txt @@ -14,6 +14,20 @@ ELSE(DEFINED ENV{NETCDF}) MESSAGE(FATAL_ERROR "The NETCDF environement variable must be set to point to your NetCDF installation before building. Stopping...") ENDIF(DEFINED ENV{NETCDF}) +set(NCEPLIBS_DIR /usr/local/NCEPlibs-20180401) +IF(DEFINED ENV{NCEPLIBS_DIR}) + MESSAGE("The NCEPLIBS_DIR env. variable is $ENV{NCEPLIBS_DIR}") + set(NCEPLIBS_DIR ENV{NCEPLIBS_DIR}) +ELSE(DEFINED ENV{NCEPLIBS_DIR}) + MESSAGE("The NCEPLIBS_DIR env. variable is not set. Setting to default value: ${NCEPLIBS_DIR}") +ENDIF(DEFINED ENV{NCEPLIBS_DIR}) + +set(BACIO_LIB4 ${NCEPLIBS_DIR}/lib/libbacio_4.a) +set(SP_LIBd ${NCEPLIBS_DIR}/lib/libsp_v2.0.2_d.a) +set(W3NCO_LIBd ${NCEPLIBS_DIR}/lib/libw3nco_d.a) + +set(STATIC false) + SET(CCPP_SRC ${CMAKE_SOURCE_DIR}/../../ccpp/framework) SET(GFSPHYSICS_SRC ${CMAKE_SOURCE_DIR}/../../ccpp/physics) From 5bd1bc7dfd1f434f033cad7560b31c4af8cbb4e6 Mon Sep 17 00:00:00 2001 From: "Grant.Firl" Date: Tue, 4 Jun 2019 18:38:35 -0600 Subject: [PATCH 3/9] remove gmtb-scm/external directory --- external/bacio/v2.0.1/src/CMakeLists.txt | 56 - external/bacio/v2.0.1/src/Makefile | 43 - external/bacio/v2.0.1/src/bacio.c | 1245 ------ external/bacio/v2.0.1/src/baciof.f | 730 ---- external/bacio/v2.0.1/src/baciof.h | 11 - external/bacio/v2.0.1/src/bafrio.f | 427 -- external/bacio/v2.0.1/src/byteswap.c | 52 - external/bacio/v2.0.1/src/chk_endianc.f | 62 - external/bacio/v2.0.1/src/clib.h | 31 - external/sp/v2.0.2/src/CMakeLists.txt | 30 - external/sp/v2.0.2/src/Makefile | 63 - external/sp/v2.0.2/src/comp_list | 660 --- external/sp/v2.0.2/src/fftpack.F | 1091 ----- external/sp/v2.0.2/src/lapack_gen.F | 105 - external/sp/v2.0.2/src/ncpus.F | 46 - external/sp/v2.0.2/src/spanaly.f | 89 - external/sp/v2.0.2/src/spdz2uv.f | 85 - external/sp/v2.0.2/src/speps.f | 67 - external/sp/v2.0.2/src/spfft.f | 93 - external/sp/v2.0.2/src/spfft1.f | 79 - external/sp/v2.0.2/src/spffte.f | 148 - external/sp/v2.0.2/src/spfftpt.f | 64 - external/sp/v2.0.2/src/spgradq.f | 76 - external/sp/v2.0.2/src/spgradx.f | 86 - external/sp/v2.0.2/src/spgrady.f | 67 - external/sp/v2.0.2/src/splaplac.f | 61 - external/sp/v2.0.2/src/splat.F | 213 - external/sp/v2.0.2/src/splegend.f | 134 - external/sp/v2.0.2/src/splib.doc | 2621 ------------ external/sp/v2.0.2/src/sppad.f | 49 - external/sp/v2.0.2/src/spsynth.f | 165 - external/sp/v2.0.2/src/sptez.f | 83 - external/sp/v2.0.2/src/sptezd.f | 75 - external/sp/v2.0.2/src/sptezm.f | 83 - external/sp/v2.0.2/src/sptezmd.f | 78 - external/sp/v2.0.2/src/sptezmv.f | 95 - external/sp/v2.0.2/src/sptezv.f | 94 - external/sp/v2.0.2/src/sptgpm.f | 137 - external/sp/v2.0.2/src/sptgpmd.f | 96 - external/sp/v2.0.2/src/sptgpmv.f | 152 - external/sp/v2.0.2/src/sptgps.f | 540 --- external/sp/v2.0.2/src/sptgpsd.f | 104 - external/sp/v2.0.2/src/sptgpsv.f | 931 ----- external/sp/v2.0.2/src/sptgpt.f | 112 - external/sp/v2.0.2/src/sptgptd.f | 83 - external/sp/v2.0.2/src/sptgptsd.f | 138 - external/sp/v2.0.2/src/sptgptv.f | 130 - external/sp/v2.0.2/src/sptgptvd.f | 168 - external/sp/v2.0.2/src/sptran.f | 138 - external/sp/v2.0.2/src/sptrand.f | 164 - external/sp/v2.0.2/src/sptranf.f | 176 - external/sp/v2.0.2/src/sptranf0.f | 83 - external/sp/v2.0.2/src/sptranf1.f | 99 - external/sp/v2.0.2/src/sptranfv.f | 215 - external/sp/v2.0.2/src/sptranv.f | 139 - external/sp/v2.0.2/src/sptrun.f | 113 - external/sp/v2.0.2/src/sptrund.f | 121 - external/sp/v2.0.2/src/sptrung.f | 104 - external/sp/v2.0.2/src/sptrungv.f | 153 - external/sp/v2.0.2/src/sptrunl.f | 127 - external/sp/v2.0.2/src/sptrunm.f | 117 - external/sp/v2.0.2/src/sptrunmv.f | 165 - external/sp/v2.0.2/src/sptruns.f | 109 - external/sp/v2.0.2/src/sptrunsv.f | 166 - external/sp/v2.0.2/src/sptrunv.f | 177 - external/sp/v2.0.2/src/spuv2dz.f | 94 - external/sp/v2.0.2/src/spvar.f | 48 - external/sp/v2.0.2/src/spwget.f | 41 - external/w3nco/v2.0.6/src/CMakeLists.txt | 155 - external/w3nco/v2.0.6/src/Makefile | 27 - external/w3nco/v2.0.6/src/aea.f | 117 - external/w3nco/v2.0.6/src/errexit.f | 33 - external/w3nco/v2.0.6/src/errmsg.f | 29 - external/w3nco/v2.0.6/src/fparsei.f | 39 - external/w3nco/v2.0.6/src/fparser.f | 39 - external/w3nco/v2.0.6/src/gbyte.f | 108 - external/w3nco/v2.0.6/src/gbytec.f | 6 - external/w3nco/v2.0.6/src/gbytes.f | 144 - external/w3nco/v2.0.6/src/gbytesc.f | 51 - external/w3nco/v2.0.6/src/getbit.f | 87 - external/w3nco/v2.0.6/src/getgb.f | 213 - external/w3nco/v2.0.6/src/getgb1.f | 199 - external/w3nco/v2.0.6/src/getgb1r.f | 76 - external/w3nco/v2.0.6/src/getgb1re.f | 81 - external/w3nco/v2.0.6/src/getgb1s.f | 185 - external/w3nco/v2.0.6/src/getgbe.f | 223 - external/w3nco/v2.0.6/src/getgbeh.f | 215 - external/w3nco/v2.0.6/src/getgbem.f | 275 -- external/w3nco/v2.0.6/src/getgbemh.f | 265 -- external/w3nco/v2.0.6/src/getgbemn.f | 277 -- external/w3nco/v2.0.6/src/getgbemp.f | 271 -- external/w3nco/v2.0.6/src/getgbep.f | 219 - external/w3nco/v2.0.6/src/getgbex.f | 233 -- external/w3nco/v2.0.6/src/getgbexm.f | 284 -- external/w3nco/v2.0.6/src/getgbh.f | 206 - external/w3nco/v2.0.6/src/getgbm.f | 271 -- external/w3nco/v2.0.6/src/getgbmh.f | 258 -- external/w3nco/v2.0.6/src/getgbmp.f | 264 -- external/w3nco/v2.0.6/src/getgbp.f | 209 - external/w3nco/v2.0.6/src/getgi.f | 88 - external/w3nco/v2.0.6/src/getgir.f | 90 - external/w3nco/v2.0.6/src/gtbits.f | 83 - external/w3nco/v2.0.6/src/idsdef.f | 285 -- external/w3nco/v2.0.6/src/instrument.f | 111 - external/w3nco/v2.0.6/src/iw3jdn.f | 62 - external/w3nco/v2.0.6/src/iw3pds.f | 177 - external/w3nco/v2.0.6/src/iw3unp29.f | 4656 --------------------- external/w3nco/v2.0.6/src/ixgb.f | 155 - external/w3nco/v2.0.6/src/lengds.f | 40 - external/w3nco/v2.0.6/src/makwmo.f | 89 - external/w3nco/v2.0.6/src/mkfldsep.f | 105 - external/w3nco/v2.0.6/src/mova2i.c | 68 - external/w3nco/v2.0.6/src/pdsens.f | 76 - external/w3nco/v2.0.6/src/pdseup.f | 74 - external/w3nco/v2.0.6/src/putgb.f | 201 - external/w3nco/v2.0.6/src/putgbe.f | 213 - external/w3nco/v2.0.6/src/putgben.f | 223 - external/w3nco/v2.0.6/src/putgbex.f | 222 - external/w3nco/v2.0.6/src/putgbn.f | 209 - external/w3nco/v2.0.6/src/q9ie32.f | 139 - external/w3nco/v2.0.6/src/r63w72.f | 125 - external/w3nco/v2.0.6/src/sbyte.f | 79 - external/w3nco/v2.0.6/src/sbytec.f | 6 - external/w3nco/v2.0.6/src/sbytes.f | 101 - external/w3nco/v2.0.6/src/sbytesc.f | 61 - external/w3nco/v2.0.6/src/skgb.f | 78 - external/w3nco/v2.0.6/src/summary.c | 496 --- external/w3nco/v2.0.6/src/w3ai00.f | 505 --- external/w3nco/v2.0.6/src/w3ai01.f | 120 - external/w3nco/v2.0.6/src/w3ai08.f | 2848 ------------- external/w3nco/v2.0.6/src/w3ai15.f | 132 - external/w3nco/v2.0.6/src/w3ai18.f | 113 - external/w3nco/v2.0.6/src/w3ai19.f | 127 - external/w3nco/v2.0.6/src/w3ai24.f | 49 - external/w3nco/v2.0.6/src/w3ai38.f | 84 - external/w3nco/v2.0.6/src/w3ai39.f | 81 - external/w3nco/v2.0.6/src/w3aq15.f | 66 - external/w3nco/v2.0.6/src/w3as00.f | 315 -- external/w3nco/v2.0.6/src/w3difdat.f | 55 - external/w3nco/v2.0.6/src/w3doxdat.f | 40 - external/w3nco/v2.0.6/src/w3fi01.f | 33 - external/w3nco/v2.0.6/src/w3fi04.f | 122 - external/w3nco/v2.0.6/src/w3fi58.f | 115 - external/w3nco/v2.0.6/src/w3fi59.f | 129 - external/w3nco/v2.0.6/src/w3fi62.f | 215 - external/w3nco/v2.0.6/src/w3fi63.f | 4062 ------------------ external/w3nco/v2.0.6/src/w3fi64.f | 760 ---- external/w3nco/v2.0.6/src/w3fi68.f | 184 - external/w3nco/v2.0.6/src/w3fi69.f | 149 - external/w3nco/v2.0.6/src/w3fi71.f | 1769 -------- external/w3nco/v2.0.6/src/w3fi72.f | 455 --- external/w3nco/v2.0.6/src/w3fi73.f | 100 - external/w3nco/v2.0.6/src/w3fi74.f | 426 -- external/w3nco/v2.0.6/src/w3fi75.f | 1619 -------- external/w3nco/v2.0.6/src/w3fi76.f | 131 - external/w3nco/v2.0.6/src/w3fi82.f | 97 - external/w3nco/v2.0.6/src/w3fi83.f | 108 - external/w3nco/v2.0.6/src/w3fi88.f | 4750 ---------------------- external/w3nco/v2.0.6/src/w3fi92.f | 216 - external/w3nco/v2.0.6/src/w3fp11.f | 845 ---- external/w3nco/v2.0.6/src/w3fp12.f | 612 --- external/w3nco/v2.0.6/src/w3fp13.f | 920 ----- external/w3nco/v2.0.6/src/w3fs13.f | 52 - external/w3nco/v2.0.6/src/w3fs15.f | 212 - external/w3nco/v2.0.6/src/w3fs21.f | 77 - external/w3nco/v2.0.6/src/w3fs26.f | 87 - external/w3nco/v2.0.6/src/w3ft32.f | 1235 ------ external/w3nco/v2.0.6/src/w3kind.f | 34 - external/w3nco/v2.0.6/src/w3locdat.f | 43 - external/w3nco/v2.0.6/src/w3movdat.f | 53 - external/w3nco/v2.0.6/src/w3nogds.f | 446 -- external/w3nco/v2.0.6/src/w3pradat.f | 78 - external/w3nco/v2.0.6/src/w3reddat.f | 142 - external/w3nco/v2.0.6/src/w3tagb.f | 121 - external/w3nco/v2.0.6/src/w3trnarg.f | 172 - external/w3nco/v2.0.6/src/w3unpk77.f | 2580 ------------ external/w3nco/v2.0.6/src/w3utcdat.f | 67 - external/w3nco/v2.0.6/src/w3valdat.f | 50 - external/w3nco/v2.0.6/src/w3ymdh4.f | 119 - external/w3nco/v2.0.6/src/xmovex.f | 20 - external/w3nco/v2.0.6/src/xstore.f | 44 - 181 files changed, 55752 deletions(-) delete mode 100644 external/bacio/v2.0.1/src/CMakeLists.txt delete mode 100644 external/bacio/v2.0.1/src/Makefile delete mode 100644 external/bacio/v2.0.1/src/bacio.c delete mode 100644 external/bacio/v2.0.1/src/baciof.f delete mode 100644 external/bacio/v2.0.1/src/baciof.h delete mode 100644 external/bacio/v2.0.1/src/bafrio.f delete mode 100644 external/bacio/v2.0.1/src/byteswap.c delete mode 100644 external/bacio/v2.0.1/src/chk_endianc.f delete mode 100644 external/bacio/v2.0.1/src/clib.h delete mode 100644 external/sp/v2.0.2/src/CMakeLists.txt delete mode 100644 external/sp/v2.0.2/src/Makefile delete mode 100644 external/sp/v2.0.2/src/comp_list delete mode 100644 external/sp/v2.0.2/src/fftpack.F delete mode 100644 external/sp/v2.0.2/src/lapack_gen.F delete mode 100644 external/sp/v2.0.2/src/ncpus.F delete mode 100644 external/sp/v2.0.2/src/spanaly.f delete mode 100644 external/sp/v2.0.2/src/spdz2uv.f delete mode 100644 external/sp/v2.0.2/src/speps.f delete mode 100644 external/sp/v2.0.2/src/spfft.f delete mode 100644 external/sp/v2.0.2/src/spfft1.f delete mode 100644 external/sp/v2.0.2/src/spffte.f delete mode 100644 external/sp/v2.0.2/src/spfftpt.f delete mode 100644 external/sp/v2.0.2/src/spgradq.f delete mode 100644 external/sp/v2.0.2/src/spgradx.f delete mode 100644 external/sp/v2.0.2/src/spgrady.f delete mode 100644 external/sp/v2.0.2/src/splaplac.f delete mode 100644 external/sp/v2.0.2/src/splat.F delete mode 100644 external/sp/v2.0.2/src/splegend.f delete mode 100644 external/sp/v2.0.2/src/splib.doc delete mode 100644 external/sp/v2.0.2/src/sppad.f delete mode 100644 external/sp/v2.0.2/src/spsynth.f delete mode 100644 external/sp/v2.0.2/src/sptez.f delete mode 100644 external/sp/v2.0.2/src/sptezd.f delete mode 100644 external/sp/v2.0.2/src/sptezm.f delete mode 100644 external/sp/v2.0.2/src/sptezmd.f delete mode 100644 external/sp/v2.0.2/src/sptezmv.f delete mode 100644 external/sp/v2.0.2/src/sptezv.f delete mode 100644 external/sp/v2.0.2/src/sptgpm.f delete mode 100644 external/sp/v2.0.2/src/sptgpmd.f delete mode 100644 external/sp/v2.0.2/src/sptgpmv.f delete mode 100644 external/sp/v2.0.2/src/sptgps.f delete mode 100644 external/sp/v2.0.2/src/sptgpsd.f delete mode 100644 external/sp/v2.0.2/src/sptgpsv.f delete mode 100644 external/sp/v2.0.2/src/sptgpt.f delete mode 100644 external/sp/v2.0.2/src/sptgptd.f delete mode 100644 external/sp/v2.0.2/src/sptgptsd.f delete mode 100644 external/sp/v2.0.2/src/sptgptv.f delete mode 100644 external/sp/v2.0.2/src/sptgptvd.f delete mode 100644 external/sp/v2.0.2/src/sptran.f delete mode 100644 external/sp/v2.0.2/src/sptrand.f delete mode 100644 external/sp/v2.0.2/src/sptranf.f delete mode 100644 external/sp/v2.0.2/src/sptranf0.f delete mode 100644 external/sp/v2.0.2/src/sptranf1.f delete mode 100644 external/sp/v2.0.2/src/sptranfv.f delete mode 100644 external/sp/v2.0.2/src/sptranv.f delete mode 100644 external/sp/v2.0.2/src/sptrun.f delete mode 100644 external/sp/v2.0.2/src/sptrund.f delete mode 100644 external/sp/v2.0.2/src/sptrung.f delete mode 100644 external/sp/v2.0.2/src/sptrungv.f delete mode 100644 external/sp/v2.0.2/src/sptrunl.f delete mode 100644 external/sp/v2.0.2/src/sptrunm.f delete mode 100644 external/sp/v2.0.2/src/sptrunmv.f delete mode 100644 external/sp/v2.0.2/src/sptruns.f delete mode 100644 external/sp/v2.0.2/src/sptrunsv.f delete mode 100644 external/sp/v2.0.2/src/sptrunv.f delete mode 100644 external/sp/v2.0.2/src/spuv2dz.f delete mode 100644 external/sp/v2.0.2/src/spvar.f delete mode 100644 external/sp/v2.0.2/src/spwget.f delete mode 100644 external/w3nco/v2.0.6/src/CMakeLists.txt delete mode 100644 external/w3nco/v2.0.6/src/Makefile delete mode 100644 external/w3nco/v2.0.6/src/aea.f delete mode 100644 external/w3nco/v2.0.6/src/errexit.f delete mode 100644 external/w3nco/v2.0.6/src/errmsg.f delete mode 100644 external/w3nco/v2.0.6/src/fparsei.f delete mode 100644 external/w3nco/v2.0.6/src/fparser.f delete mode 100644 external/w3nco/v2.0.6/src/gbyte.f delete mode 100644 external/w3nco/v2.0.6/src/gbytec.f delete mode 100644 external/w3nco/v2.0.6/src/gbytes.f delete mode 100644 external/w3nco/v2.0.6/src/gbytesc.f delete mode 100644 external/w3nco/v2.0.6/src/getbit.f delete mode 100644 external/w3nco/v2.0.6/src/getgb.f delete mode 100644 external/w3nco/v2.0.6/src/getgb1.f delete mode 100644 external/w3nco/v2.0.6/src/getgb1r.f delete mode 100644 external/w3nco/v2.0.6/src/getgb1re.f delete mode 100644 external/w3nco/v2.0.6/src/getgb1s.f delete mode 100644 external/w3nco/v2.0.6/src/getgbe.f delete mode 100644 external/w3nco/v2.0.6/src/getgbeh.f delete mode 100644 external/w3nco/v2.0.6/src/getgbem.f delete mode 100644 external/w3nco/v2.0.6/src/getgbemh.f delete mode 100644 external/w3nco/v2.0.6/src/getgbemn.f delete mode 100644 external/w3nco/v2.0.6/src/getgbemp.f delete mode 100644 external/w3nco/v2.0.6/src/getgbep.f delete mode 100644 external/w3nco/v2.0.6/src/getgbex.f delete mode 100644 external/w3nco/v2.0.6/src/getgbexm.f delete mode 100644 external/w3nco/v2.0.6/src/getgbh.f delete mode 100644 external/w3nco/v2.0.6/src/getgbm.f delete mode 100644 external/w3nco/v2.0.6/src/getgbmh.f delete mode 100644 external/w3nco/v2.0.6/src/getgbmp.f delete mode 100644 external/w3nco/v2.0.6/src/getgbp.f delete mode 100644 external/w3nco/v2.0.6/src/getgi.f delete mode 100644 external/w3nco/v2.0.6/src/getgir.f delete mode 100644 external/w3nco/v2.0.6/src/gtbits.f delete mode 100644 external/w3nco/v2.0.6/src/idsdef.f delete mode 100644 external/w3nco/v2.0.6/src/instrument.f delete mode 100644 external/w3nco/v2.0.6/src/iw3jdn.f delete mode 100644 external/w3nco/v2.0.6/src/iw3pds.f delete mode 100644 external/w3nco/v2.0.6/src/iw3unp29.f delete mode 100644 external/w3nco/v2.0.6/src/ixgb.f delete mode 100644 external/w3nco/v2.0.6/src/lengds.f delete mode 100644 external/w3nco/v2.0.6/src/makwmo.f delete mode 100644 external/w3nco/v2.0.6/src/mkfldsep.f delete mode 100644 external/w3nco/v2.0.6/src/mova2i.c delete mode 100644 external/w3nco/v2.0.6/src/pdsens.f delete mode 100644 external/w3nco/v2.0.6/src/pdseup.f delete mode 100644 external/w3nco/v2.0.6/src/putgb.f delete mode 100644 external/w3nco/v2.0.6/src/putgbe.f delete mode 100644 external/w3nco/v2.0.6/src/putgben.f delete mode 100644 external/w3nco/v2.0.6/src/putgbex.f delete mode 100644 external/w3nco/v2.0.6/src/putgbn.f delete mode 100644 external/w3nco/v2.0.6/src/q9ie32.f delete mode 100644 external/w3nco/v2.0.6/src/r63w72.f delete mode 100644 external/w3nco/v2.0.6/src/sbyte.f delete mode 100644 external/w3nco/v2.0.6/src/sbytec.f delete mode 100644 external/w3nco/v2.0.6/src/sbytes.f delete mode 100644 external/w3nco/v2.0.6/src/sbytesc.f delete mode 100644 external/w3nco/v2.0.6/src/skgb.f delete mode 100644 external/w3nco/v2.0.6/src/summary.c delete mode 100644 external/w3nco/v2.0.6/src/w3ai00.f delete mode 100644 external/w3nco/v2.0.6/src/w3ai01.f delete mode 100644 external/w3nco/v2.0.6/src/w3ai08.f delete mode 100644 external/w3nco/v2.0.6/src/w3ai15.f delete mode 100644 external/w3nco/v2.0.6/src/w3ai18.f delete mode 100644 external/w3nco/v2.0.6/src/w3ai19.f delete mode 100644 external/w3nco/v2.0.6/src/w3ai24.f delete mode 100644 external/w3nco/v2.0.6/src/w3ai38.f delete mode 100644 external/w3nco/v2.0.6/src/w3ai39.f delete mode 100644 external/w3nco/v2.0.6/src/w3aq15.f delete mode 100644 external/w3nco/v2.0.6/src/w3as00.f delete mode 100644 external/w3nco/v2.0.6/src/w3difdat.f delete mode 100644 external/w3nco/v2.0.6/src/w3doxdat.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi01.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi04.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi58.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi59.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi62.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi63.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi64.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi68.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi69.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi71.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi72.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi73.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi74.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi75.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi76.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi82.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi83.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi88.f delete mode 100644 external/w3nco/v2.0.6/src/w3fi92.f delete mode 100644 external/w3nco/v2.0.6/src/w3fp11.f delete mode 100644 external/w3nco/v2.0.6/src/w3fp12.f delete mode 100644 external/w3nco/v2.0.6/src/w3fp13.f delete mode 100644 external/w3nco/v2.0.6/src/w3fs13.f delete mode 100644 external/w3nco/v2.0.6/src/w3fs15.f delete mode 100644 external/w3nco/v2.0.6/src/w3fs21.f delete mode 100644 external/w3nco/v2.0.6/src/w3fs26.f delete mode 100644 external/w3nco/v2.0.6/src/w3ft32.f delete mode 100644 external/w3nco/v2.0.6/src/w3kind.f delete mode 100644 external/w3nco/v2.0.6/src/w3locdat.f delete mode 100644 external/w3nco/v2.0.6/src/w3movdat.f delete mode 100644 external/w3nco/v2.0.6/src/w3nogds.f delete mode 100644 external/w3nco/v2.0.6/src/w3pradat.f delete mode 100644 external/w3nco/v2.0.6/src/w3reddat.f delete mode 100644 external/w3nco/v2.0.6/src/w3tagb.f delete mode 100644 external/w3nco/v2.0.6/src/w3trnarg.f delete mode 100644 external/w3nco/v2.0.6/src/w3unpk77.f delete mode 100644 external/w3nco/v2.0.6/src/w3utcdat.f delete mode 100644 external/w3nco/v2.0.6/src/w3valdat.f delete mode 100644 external/w3nco/v2.0.6/src/w3ymdh4.f delete mode 100644 external/w3nco/v2.0.6/src/xmovex.f delete mode 100644 external/w3nco/v2.0.6/src/xstore.f diff --git a/external/bacio/v2.0.1/src/CMakeLists.txt b/external/bacio/v2.0.1/src/CMakeLists.txt deleted file mode 100644 index fe10d3bdf..000000000 --- a/external/bacio/v2.0.1/src/CMakeLists.txt +++ /dev/null @@ -1,56 +0,0 @@ -SET(bacio_source_code ${BACIOLIB_SRC}/baciof.f - ${BACIOLIB_SRC}/bacio.c -) - -#set Fortran compiler flags, depends on compiler -if (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - set(f_flags -O3 -fbacktrace -fPIC) -elseif (${CMAKE_Fortran_COMPILER_ID} MATCHES "Intel") - set(f_flags -O3 -xHOST -traceback -fPIC) -elseif (${CMAKE_Fortran_COMPILER_ID} MATCHES "PGI") - set(f_flags -O3 -traceback -fPIC) -else (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - message ("CMAKE_Fortran_COMPILER full path: " ${CMAKE_Fortran_COMPILER}) - message ("Fortran compiler: " ${CMAKE_Fortran_COMPILER_ID}) - message (FATAL_ERROR "This library has only been compiled with gfortran, pgf90 and ifort. If another compiler is needed, the appropriate flags must be added in ${BACIOLIB_SRC}/CMakeLists.txt") -endif (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - -#set C compiler flags, depends on compiler and os -# compiler -if (${CMAKE_C_COMPILER_ID} MATCHES "GNU" OR ${CMAKE_C_COMPILER_ID} MATCHES "Clang") - set(c_flags -O3 -DUNDERSCORE -fPIC) -elseif (${CMAKE_C_COMPILER_ID} MATCHES "Intel") - set(c_flags -O3 -DUNDERSCORE -fPIC) -elseif (${CMAKE_Fortran_COMPILER_ID} MATCHES "PGI") - set(c_flags -O3 -DUNDERSCORE -fPIC) -else (${CMAKE_C_COMPILER_ID} MATCHES "GNU" OR ${CMAKE_C_COMPILER_ID} MATCHES "Clang") - message ("CMAKE_Fortran_COMPILER full path: " ${CMAKE_C_COMPILER}) - message ("Fortran compiler: " ${CMAKE_C_COMPILER_ID}) - message (FATAL_ERROR "This program has only been compiled with gcc, clang, pgcc and icc. If another compiler is needed, the appropriate flags must be added in ${BACIOLIB_SRC}/CMakeLists.txt") -endif (${CMAKE_C_COMPILER_ID} MATCHES "GNU" OR ${CMAKE_C_COMPILER_ID} MATCHES "Clang") -# os -if (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") - set(c_flags ${c_flags} -DMACOSX) -elseif (${CMAKE_SYSTEM_NAME} MATCHES "Linux") - set(c_flags ${c_flags} -DLINUX) -else (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") - message (FATAL_ERROR "This library has only been compiled on Linux and Darwin platforms. If another platform is needed, the appropriate flags must be added in ${BACIOLIB_SRC}/CMakeLists.txt") -endif (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") - -#add OpenMP -set(c_flags ${c_flags} ${OpenMP_C_FLAGS}) -set(f_flags ${f_flags} ${OpenMP_Fortran_FLAGS}) - -if(${CMAKE_VERSION} LESS 3.3) - file(GLOB f_files *.f) - string (REPLACE ";" " " f_flags_str "${f_flags}") - set(CMAKE_Fortran_FLAGS "${f_flags_str}") - file(GLOB c_files *.c) - string (REPLACE ";" " " c_flags_str "${c_flags}") - set(CMAKE_C_FLAGS "${c_flags_str}") -else(${CMAKE_VERSION} LESS 3.3) - add_compile_options("$<$:${f_flags}>") - add_compile_options("$<$:${c_flags}>") -endif (${CMAKE_VERSION} LESS 3.3) - -ADD_LIBRARY(bacio STATIC ${bacio_source_code}) diff --git a/external/bacio/v2.0.1/src/Makefile b/external/bacio/v2.0.1/src/Makefile deleted file mode 100644 index 5426588c6..000000000 --- a/external/bacio/v2.0.1/src/Makefile +++ /dev/null @@ -1,43 +0,0 @@ -# bacio Makefile - -############################################################### -# -# AUTHOR: Gilbert - W/NP11 -# -# DATE: 01/11/1999 -# -# PURPOSE: This script uses the make utility to update the bacio -# archive libraries. -# -############################################################### - -include ../../../../macros.make - -FCMP = $(FCserial) -CCMP = $(CC) -LIB = ../../../../libbacio_4.a -FFLAGS = $(BACIO_FFLAGS) -AFLAGS = $(ARFLAGS) -CFLAGS = $(BACIO_CFLAGS) -OBJS = bacio.o baciof.o bafrio.o byteswap.o chk_endianc.o - -$(LIB): $(OBJS) - ar -rv $(AFLAGS) $@ $^ - -bacio.o: bacio.c clib.h - $(CCMP) -c $(CFLAGS) bacio.c - -baciof.o: baciof.f - $(FCMP) -c $(FFLAGS) baciof.f - -bafrio.o: bafrio.f - $(FCMP) -c $(FFLAGS) bafrio.f - -byteswap.o: byteswap.c - $(CCMP) -c $(CFLAGS) byteswap.c - -chk_endianc.o: chk_endianc.f - $(FCMP) -c $(FFLAGS) chk_endianc.f - -clean: - $(RM) *.o *.mod $(LIB) diff --git a/external/bacio/v2.0.1/src/bacio.c b/external/bacio/v2.0.1/src/bacio.c deleted file mode 100644 index f6b0834a4..000000000 --- a/external/bacio/v2.0.1/src/bacio.c +++ /dev/null @@ -1,1245 +0,0 @@ -/* Fortran-callable routines to read and write characther (bacio) and */ -/* numeric (banio) data byte addressably */ -/* Robert Grumbine 16 March 1998 */ -/* v1.1: Put diagnostic output under control of define VERBOSE or QUIET */ -/* Add option of non-seeking read/write */ -/* Return code for fewer data read/written than requested */ -/* v1.2: Add cray compatibility 20 April 1998 Robert Grumbine */ -/* v1.3: Add IBMSP compatibility (IBM4, IBM8) - Add modes BAOPEN_WONLY_TRUNC, BAOPEN_WONLY_APPEND - Use isgraph instead of isalnum + a short list of accepted characters - for filename check - 12 Dec 2000 Stephen Gilbert */ -/* negative return codes are wrapped to positive, revise return codes - verify that banio and bacio have same contents - update comments - 29 Oct 2008 Robert Grumbine */ -/* v1.4: 21 Nov 2008 - Add baciol and baniol functions, versions to work with files - over 2 Gb - Robert Grumbine */ -/* Aug 2012 Jun Wang: fix c filename length because the c string - needs to end with "null" terminator , and free allocated cfile - name realname to avoid memory leak */ -/* Sep 2012 Jun Wang: remove execute permission on the data file - generated by bacio */ - -#include -#include -#include -#include -#include -#ifdef MACOSX -#include -#else -#include -#endif -#include -#include - -/* Include the C library file for definition/control */ -/* Things that might be changed for new systems are there. */ -/* This source file should not (need to) be edited, merely recompiled */ -#include "clib.h" - - -/* Return Codes: */ -/* 0 All was well */ -/* 255 Tried to open read only _and_ write only */ -/* 254 Tried to read and write in the same call */ -/* 253 Internal failure in name processing */ -/* 252 Failure in opening file */ -/* 251 Tried to read on a write-only file */ -/* 250 Failed in read to find the 'start' location */ -/* 249 Tried to write to a read only file */ -/* 248 Failed in write to find the 'start' location */ -/* 247 Error in close */ -/* 246 Read or wrote fewer data than requested */ -/* 102 Massive catastrophe -- datary pointer is NULL */ - -/* Note: In your Fortran code, call bacio, not bacio_. */ -/*int bacio_(int * mode, int * start, int * size, int * no, int * nactual, */ -/* int * fdes, const char *fname, char *data, int namelen, */ -/* int datanamelen) */ -/* Arguments: */ -/* Mode is the integer specifying operations to be performed */ -/* see the clib.inc file for the values. Mode is obtained */ -/* by adding together the values corresponding to the operations */ -/* The best method is to include the clib.inc file and refer to the */ -/* names for the operations rather than rely on hard-coded values */ -/* Start is the byte number to start your operation from. 0 is the first */ -/* byte in the file, not 1. */ -/* Newpos is the position in the file after a read or write has been */ -/* performed. You'll need this if you're doing 'seeking' read/write */ -/* Size is the size of the objects you are trying to read. Rely on the */ -/* values in the locale.inc file. Types are CHARACTER, INTEGER, REAL, */ -/* COMPLEX. Specify the correct value by using SIZEOF_type, where type */ -/* is one of these. (After having included the locale.inc file) */ -/* no is the number of things to read or write (characters, integers, */ -/* whatever) */ -/* nactual is the number of things actually read or written. Check that */ -/* you got what you wanted. */ -/* fdes is an integer 'file descriptor'. This is not a Fortran Unit Number */ -/* You can use it, however, to refer to files you've previously opened. */ -/* fname is the name of the file. This only needs to be defined when you */ -/* are opening a file. It must be (on the Fortran side) declared as */ -/* CHARACTER*N, where N is a length greater than or equal to the length */ -/* of the file name. CHARACTER*1 fname[80] (for example) will fail. */ -/* data is the name of the entity (variable, vector, array) that you want */ -/* to write data out from or read it in to. The fact that C is declaring */ -/* it to be a char * does not affect your fortran. */ -/* namelen - Do NOT specify this. It is created automagically by the */ -/* Fortran compiler */ -/* datanamelen - Ditto */ - - -/* What is going on here is that although the Fortran caller will always */ -/* be calling bacio, the called C routine name will change from system */ -/* to system. */ -#ifdef CRAY90 - #include - int BACIO - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, - _fcd fcd_fname, _fcd fcd_datary) { - char *fname, *datary; - int namelen; -#endif -#ifdef HP - int bacio - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef SGI - int bacio_ - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef LINUX - int bacio_ - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef LINUXF90 - int BACIO - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef MACOSX - int bacio_ - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef VPP5000 - int bacio_ - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef IBM4 - int bacio - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef IBM8 - long long int bacio - (long long int * mode, long long int * start, long long int *newpos, - long long int * size, long long int * no, - long long int * nactual, long long int * fdes, const char *fname, - char *datary, - long long int namelen, long long int datanamelen) { -#endif - int i, j, jret, seekret; - char *realname; - int tcharval; - size_t count; - -/* Initialization(s) */ - *nactual = 0; - -/* Check for illegal combinations of options */ - if (( BAOPEN_RONLY & *mode) && - ( (BAOPEN_WONLY & *mode) || (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) ) ) { - #ifdef VERBOSE - printf("illegal -- trying to open both read only and write only\n"); - #endif - return 255; - } - if ( (BAREAD & *mode ) && (BAWRITE & *mode) ) { - #ifdef VERBOSE - printf("illegal -- trying to both read and write in the same call\n"); - #endif - return 254; - } - -/* This section handles Fortran to C translation of strings so as to */ -/* be able to open the files Fortran is expecting to be opened. */ - #ifdef CRAY90 - namelen = _fcdlen(fcd_fname); - fname = _fcdtocp(fcd_fname); - #endif - if ( (BAOPEN_RONLY & *mode) || (BAOPEN_WONLY & *mode) || - (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) || - (BAOPEN_RW & *mode) ) { - #ifdef VERBOSE - printf("Will be opening a file %s %d\n", fname, namelen); fflush(stdout); - printf("Strlen %d namelen %d\n", strlen(fname), namelen); fflush(stdout); - #endif - realname = (char *) malloc( (namelen+1) * sizeof(char) ) ; - if (realname == NULL) { - #ifdef VERBOSE - printf("failed to mallocate realname %d = namelen\n", namelen); - fflush(stdout); - #endif - return 253; - } - - i=0; - while (i < namelen && isgraph(fname[i])) { - realname[i]=fname[i]; - i++; - } - realname[i] = '\0'; - } - -/* Open files with correct read/write and file permission. */ - if (BAOPEN_RONLY & *mode) { - #ifdef VERBOSE - printf("open read only %s\n", realname); - #endif - *fdes = open(realname, O_RDONLY , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY & *mode ) { - #ifdef VERBOSE - printf("open write only %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY_TRUNC & *mode ) { - #ifdef VERBOSE - printf("open write only with truncation %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT | O_TRUNC , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY_APPEND & *mode ) { - #ifdef VERBOSE - printf("open write only with append %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT | O_APPEND , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_RW & *mode) { - #ifdef VERBOSE - printf("open read-write %s\n", realname); - #endif - *fdes = open(realname, O_RDWR | O_CREAT , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else { - #ifdef VERBOSE - printf("no openings\n"); - #endif - } - if (*fdes < 0) { - #ifdef VERBOSE - printf("error in file descriptor! *fdes %d\n", *fdes); - #endif - return 252; - } - else { - #ifdef VERBOSE - printf("file descriptor = %d\n",*fdes ); - #endif - } - - -/* Read data as requested */ - if (BAREAD & *mode && - ( (BAOPEN_WONLY & *mode) || (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) ) ) { - #ifdef VERBOSE - printf("Error, trying to read while in write only mode!\n"); - #endif - return 251; - } - else if (BAREAD & *mode ) { - /* Read in some data */ - if (! (*mode & NOSEEK) ) { - seekret = lseek(*fdes, *start, SEEK_SET); - if (seekret == -1) { - #ifdef VERBOSE - printf("error in seeking to %d\n",*start); - #endif - return 250; - } - #ifdef VERBOSE - else { - printf("Seek successful, seek ret %d, start %d\n", seekret, *start); - } - #endif - } - #ifdef CRAY90 - datary = _fcdtocp(fcd_datary); - #endif - if (datary == NULL) { - printf("Massive catastrophe -- datary pointer is NULL\n"); - return 102; - } - #ifdef VERBOSE - printf("file descriptor, datary = %d %d\n", *fdes, (int) datary); - #endif - count = (size_t) *no; - jret = read(*fdes, (void *) datary, count); - if (jret != *no) { - #ifdef VERBOSE - printf("did not read in the requested number of bytes\n"); - printf("read in %d bytes instead of %d \n",jret, *no); - #endif - } - else { - #ifdef VERBOSE - printf("read in %d bytes requested \n", *no); - #endif - } - *nactual = jret; - *newpos = *start + jret; - } -/* Done with reading */ - -/* See if we should be writing */ - if ( BAWRITE & *mode && BAOPEN_RONLY & *mode ) { - #ifdef VERBOSE - printf("Trying to write on a read only file \n"); - #endif - return 249; - } - else if ( BAWRITE & *mode ) { - if (! (*mode & NOSEEK) ) { - seekret = lseek(*fdes, *start, SEEK_SET); - if (seekret == -1) { - #ifdef VERBOSE - printf("error in seeking to %d\n",*start); - #endif - return 248; - } - #ifdef VERBOSE - else { - printf("Seek successful, seek ret %d, start %d\n", seekret, *start); - } - #endif - } - #ifdef CRAY90 - datary = _fcdtocp(fcd_datary); - #endif - if (datary == NULL) { - printf("Massive catastrophe -- datary pointer is NULL\n"); - return 102; - } - #ifdef VERBOSE - printf("write file descriptor, datary = %d %d\n", *fdes, (int) datary); - #endif - count = (size_t) *no; - jret = write(*fdes, (void *) datary, count); - if (jret != *no) { - #ifdef VERBOSE - printf("did not write out the requested number of bytes\n"); - printf("wrote %d bytes instead\n", jret); - #endif - *nactual = jret; - *newpos = *start + jret; - } - else { - #ifdef VERBOSE - printf("wrote %d bytes \n", jret); - #endif - *nactual = jret; - *newpos = *start + jret; - } - } -/* Done with writing */ - - -/* Close file if requested */ - if (BACLOSE & *mode ) { - jret = close(*fdes); - if (jret != 0) { - #ifdef VERBOSE - printf("close failed! jret = %d\n",jret); - #endif - return 247; - } - } -/* Done closing */ - -/* Free the realname pointer to prevent memory leak */ - if ( (BAOPEN_RONLY & *mode) || (BAOPEN_WONLY & *mode) || - (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) || - (BAOPEN_RW & *mode) ) { - free(realname); - } - -/* Check that if we were reading or writing, that we actually got what */ -/* we expected, else return a -10. Return 0 (success) if we're here */ -/* and weren't reading or writing */ - if ( (*mode & BAREAD || *mode & BAWRITE) && (*nactual != *no) ) { - return 246; - } - else { - return 0; - } -} -#ifdef CRAY90 - #include - int BANIO - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, - _fcd fcd_fname, void *datary) { - char *fname; - int namelen; -#endif -#ifdef HP - int banio - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef SGI - int banio_ - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef LINUX - int banio_ - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef LINUXF90 - int BANIO - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef MACOSX - int banio_ - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef VPP5000 - int banio_ - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef IBM4 - int banio - (int * mode, int * start, int *newpos, int * size, int * no, - int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef IBM8 - long long int banio - (long long int * mode, long long int * start, long long int *newpos, - long long int * size, long long int * no, - long long int * nactual, long long int * fdes, const char *fname, - char *datary, - long long int namelen ) { -#endif - int i, j, jret, seekret; - char *realname; - int tcharval; - size_t count; - -/* Initialization(s) */ - *nactual = 0; - -/* Check for illegal combinations of options */ - if (( BAOPEN_RONLY & *mode) && - ( (BAOPEN_WONLY & *mode) || (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) ) ) { - #ifdef VERBOSE - printf("illegal -- trying to open both read only and write only\n"); - #endif - return 255; - } - if ( (BAREAD & *mode ) && (BAWRITE & *mode) ) { - #ifdef VERBOSE - printf("illegal -- trying to both read and write in the same call\n"); - #endif - return 254; - } - -/* This section handles Fortran to C translation of strings so as to */ -/* be able to open the files Fortran is expecting to be opened. */ - #ifdef CRAY90 - namelen = _fcdlen(fcd_fname); - fname = _fcdtocp(fcd_fname); - #endif - if ( (BAOPEN_RONLY & *mode) || (BAOPEN_WONLY & *mode) || - (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) || - (BAOPEN_RW & *mode) ) { - #ifdef VERBOSE - printf("Will be opening a file %s %d\n", fname, namelen); fflush(stdout); - printf("Strlen %d namelen %d\n", strlen(fname), namelen); fflush(stdout); - #endif - realname = (char *) malloc( (namelen+1) * sizeof(char) ) ; - if (realname == NULL) { - #ifdef VERBOSE - printf("failed to mallocate realname %d = namelen\n", namelen); - fflush(stdout); - #endif - return 253; - } - - i=0; - while (i < namelen && isgraph(fname[i])) { - realname[i]=fname[i]; - i++; - } - realname[i] = '\0'; - } - -/* Open files with correct read/write and file permission. */ - if (BAOPEN_RONLY & *mode) { - #ifdef VERBOSE - printf("open read only %s\n", realname); - #endif - *fdes = open(realname, O_RDONLY , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY & *mode ) { - #ifdef VERBOSE - printf("open write only %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY_TRUNC & *mode ) { - #ifdef VERBOSE - printf("open write only with truncation %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT | O_TRUNC , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY_APPEND & *mode ) { - #ifdef VERBOSE - printf("open write only with append %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT | O_APPEND , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_RW & *mode) { - #ifdef VERBOSE - printf("open read-write %s\n", realname); - #endif - *fdes = open(realname, O_RDWR | O_CREAT , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else { - #ifdef VERBOSE - printf("no openings\n"); - #endif - } - if (*fdes < 0) { - #ifdef VERBOSE - printf("error in file descriptor! *fdes %d\n", *fdes); - #endif - return 252; - } - else { - #ifdef VERBOSE - printf("file descriptor = %d\n",*fdes ); - #endif - } - - -/* Read data as requested */ - if (BAREAD & *mode && - ( (BAOPEN_WONLY & *mode) || (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) ) ) { - #ifdef VERBOSE - printf("Error, trying to read while in write only mode!\n"); - #endif - return 251; - } - else if (BAREAD & *mode ) { - /* Read in some data */ - if (! (*mode & NOSEEK) ) { - seekret = lseek(*fdes, *start, SEEK_SET); - if (seekret == -1) { - #ifdef VERBOSE - printf("error in seeking to %d\n",*start); - #endif - return 250; - } - #ifdef VERBOSE - else { - printf("Seek successful, seek ret %d, start %d\n", seekret, *start); - } - #endif - } - jret = read(*fdes, datary, *no*(*size) ); - if (jret != *no*(*size) ) { - #ifdef VERBOSE - printf("did not read in the requested number of items\n"); - printf("read in %d items of %d \n",jret/(*size), *no); - #endif - *nactual = jret/(*size); - *newpos = *start + jret; - } - #ifdef VERBOSE - printf("read in %d items \n", jret/(*size)); - #endif - *nactual = jret/(*size); - *newpos = *start + jret; - } -/* Done with reading */ - -/* See if we should be writing */ - if ( BAWRITE & *mode && BAOPEN_RONLY & *mode ) { - #ifdef VERBOSE - printf("Trying to write on a read only file \n"); - #endif - return 249; - } - else if ( BAWRITE & *mode ) { - if (! (*mode & NOSEEK) ) { - seekret = lseek(*fdes, *start, SEEK_SET); - if (seekret == -1) { - #ifdef VERBOSE - printf("error in seeking to %d\n",*start); - #endif - return 248; - } - #ifdef VERBOSE - else { - printf("Seek successful, seek ret %d, start %d\n", seekret, *start); - } - #endif - } - jret = write(*fdes, datary, *no*(*size)); - if (jret != *no*(*size)) { - #ifdef VERBOSE - printf("did not write out the requested number of items\n"); - printf("wrote %d items instead\n", jret/(*size) ); - #endif - *nactual = jret/(*size) ; - *newpos = *start + jret; - } - else { - #ifdef VERBOSE - printf("wrote %d items \n", jret/(*size) ); - #endif - *nactual = jret/(*size) ; - *newpos = *start + jret; - } - } -/* Done with writing */ - - -/* Close file if requested */ - if (BACLOSE & *mode ) { - jret = close(*fdes); - if (jret != 0) { - #ifdef VERBOSE - printf("close failed! jret = %d\n",jret); - #endif - return 247; - } - } -/* Done closing */ - -/* Free the realname pointer to prevent memory leak */ - if ( (BAOPEN_RONLY & *mode) || (BAOPEN_WONLY & *mode) || - (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) || - (BAOPEN_RW & *mode) ) { - free(realname); - } - -/* Check that if we were reading or writing, that we actually got what */ -/* we expected, else return a -10. Return 0 (success) if we're here */ -/* and weren't reading or writing */ - if ( (*mode & BAREAD || *mode & BAWRITE) && (*nactual != *no) ) { - return 246; - } - else { - return 0; - } -} - -/* Now repeat with new names for long int arguments, needed for */ -/* files > 2 Gb */ -/* Robert Grumbine 21 November 2008 */ - -/* Note: In your Fortran code, call bacio, not bacio_. */ -/*int baciol_(int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, */ -/* int * fdes, const char *fname, char *data, int namelen, */ -/* int datanamelen) */ -#ifdef CRAY90 - #include - int BACIOL - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, - _fcd fcd_fname, _fcd fcd_datary) { - char *fname, *datary; - int namelen; -#endif -#ifdef HP - int baciol - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef SGI - int baciol_ - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef LINUX - int baciol_ - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef LINUXF90 - int BACIOL - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef MACOSX - int baciol_ - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef VPP5000 - int baciol_ - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef IBM4 - int baciol - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen, int datanamelen) { -#endif -#ifdef IBM8 - long long int baciol - (long long int * mode, long long int * start, long long int *newpos, - long long int * size, long long int * no, - long long int * nactual, long long int * fdes, const char *fname, - char *datary, - long long int namelen, long long int datanamelen) { -#endif - int i, j, jret, seekret; - char *realname; - int tcharval; - size_t count; - -/* Initialization(s) */ - *nactual = 0; - -/* Check for illegal combinations of options */ - if (( BAOPEN_RONLY & *mode) && - ( (BAOPEN_WONLY & *mode) || (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) ) ) { - #ifdef VERBOSE - printf("illegal -- trying to open both read only and write only\n"); - #endif - return 255; - } - if ( (BAREAD & *mode ) && (BAWRITE & *mode) ) { - #ifdef VERBOSE - printf("illegal -- trying to both read and write in the same call\n"); - #endif - return 254; - } - -/* This section handles Fortran to C translation of strings so as to */ -/* be able to open the files Fortran is expecting to be opened. */ - #ifdef CRAY90 - namelen = _fcdlen(fcd_fname); - fname = _fcdtocp(fcd_fname); - #endif - if ( (BAOPEN_RONLY & *mode) || (BAOPEN_WONLY & *mode) || - (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) || - (BAOPEN_RW & *mode) ) { - #ifdef VERBOSE - printf("Will be opening a file %s %d\n", fname, namelen); fflush(stdout); - printf("Strlen %d namelen %d\n", strlen(fname), namelen); fflush(stdout); - #endif - realname = (char *) malloc( (namelen+1) * sizeof(char) ) ; - if (realname == NULL) { - #ifdef VERBOSE - printf("failed to mallocate realname %d = namelen\n", namelen); - fflush(stdout); - #endif - return 253; - } - - i=0; - while (i < namelen && isgraph(fname[i])) { - realname[i]=fname[i]; - i++; - } - realname[i] = '\0'; - - } - -/* Open files with correct read/write and file permission. */ - if (BAOPEN_RONLY & *mode) { - #ifdef VERBOSE - printf("open read only %s\n", realname); - #endif - *fdes = open(realname, O_RDONLY , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY & *mode ) { - #ifdef VERBOSE - printf("open write only %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY_TRUNC & *mode ) { - #ifdef VERBOSE - printf("open write only with truncation %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT | O_TRUNC , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY_APPEND & *mode ) { - #ifdef VERBOSE - printf("open write only with append %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT | O_APPEND , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_RW & *mode) { - #ifdef VERBOSE - printf("open read-write %s\n", realname); - #endif - *fdes = open(realname, O_RDWR | O_CREAT , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else { - #ifdef VERBOSE - printf("no openings\n"); - #endif - } - if (*fdes < 0) { - #ifdef VERBOSE - printf("error in file descriptor! *fdes %d\n", *fdes); - #endif - return 252; - } - else { - #ifdef VERBOSE - printf("file descriptor = %d\n",*fdes ); - #endif - } - - -/* Read data as requested */ - if (BAREAD & *mode && - ( (BAOPEN_WONLY & *mode) || (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) ) ) { - #ifdef VERBOSE - printf("Error, trying to read while in write only mode!\n"); - #endif - return 251; - } - else if (BAREAD & *mode ) { - /* Read in some data */ - if (! (*mode & NOSEEK) ) { - seekret = lseek(*fdes, *start, SEEK_SET); - if (seekret == -1) { - #ifdef VERBOSE - printf("error in seeking to %d\n",*start); - #endif - return 250; - } - #ifdef VERBOSE - else { - printf("Seek successful, seek ret %d, start %d\n", seekret, *start); - } - #endif - } - #ifdef CRAY90 - datary = _fcdtocp(fcd_datary); - #endif - if (datary == NULL) { - printf("Massive catastrophe -- datary pointer is NULL\n"); - return 102; - } - #ifdef VERBOSE - printf("file descriptor, datary = %d %d\n", *fdes, (int) datary); - #endif - count = (size_t) *no; - jret = read(*fdes, (void *) datary, count); - if (jret != *no) { - #ifdef VERBOSE - printf("did not read in the requested number of bytes\n"); - printf("read in %d bytes instead of %d \n",jret, *no); - #endif - } - else { - #ifdef VERBOSE - printf("read in %d bytes requested \n", *no); - #endif - } - *nactual = jret; - *newpos = *start + jret; - } -/* Done with reading */ - -/* See if we should be writing */ - if ( BAWRITE & *mode && BAOPEN_RONLY & *mode ) { - #ifdef VERBOSE - printf("Trying to write on a read only file \n"); - #endif - return 249; - } - else if ( BAWRITE & *mode ) { - if (! (*mode & NOSEEK) ) { - seekret = lseek(*fdes, *start, SEEK_SET); - if (seekret == -1) { - #ifdef VERBOSE - printf("error in seeking to %d\n",*start); - #endif - return 248; - } - #ifdef VERBOSE - else { - printf("Seek successful, seek ret %d, start %d\n", seekret, *start); - } - #endif - } - #ifdef CRAY90 - datary = _fcdtocp(fcd_datary); - #endif - if (datary == NULL) { - printf("Massive catastrophe -- datary pointer is NULL\n"); - return 102; - } - #ifdef VERBOSE - printf("write file descriptor, datary = %d %d\n", *fdes, (int) datary); - #endif - count = (size_t) *no; - jret = write(*fdes, (void *) datary, count); - if (jret != *no) { - #ifdef VERBOSE - printf("did not write out the requested number of bytes\n"); - printf("wrote %d bytes instead\n", jret); - #endif - *nactual = jret; - *newpos = *start + jret; - } - else { - #ifdef VERBOSE - printf("wrote %d bytes \n", jret); - #endif - *nactual = jret; - *newpos = *start + jret; - } - } -/* Done with writing */ - - -/* Close file if requested */ - if (BACLOSE & *mode ) { - jret = close(*fdes); - if (jret != 0) { - #ifdef VERBOSE - printf("close failed! jret = %d\n",jret); - #endif - return 247; - } - } -/* Done closing */ - -/* Free the realname pointer to prevent memory leak */ - if ( (BAOPEN_RONLY & *mode) || (BAOPEN_WONLY & *mode) || - (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) || - (BAOPEN_RW & *mode) ) { - free(realname); - } - -/* Check that if we were reading or writing, that we actually got what */ -/* we expected, else return a -10. Return 0 (success) if we're here */ -/* and weren't reading or writing */ - if ( (*mode & BAREAD || *mode & BAWRITE) && (*nactual != *no) ) { - return 246; - } - else { - return 0; - } -} -#ifdef CRAY90 - #include - int BANI0L - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, - _fcd fcd_fname, void *datary) { - char *fname; - int namelen; -#endif -#ifdef HP - int baniol - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef SGI - int baniol_ - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef LINUX - int baniol_ - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef LINUXF90 - int BANIO - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef MACOSX - int baniol_ - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef VPP5000 - int baniol_ - (int * mode, long int * start, long int *newpos, int * size, long int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef IBM4 - int baniol - (int * mode, long int * start, long int *newpos, long int * size, int * no, - long int * nactual, int * fdes, const char *fname, char *datary, - int namelen ) { -#endif -#ifdef IBM8 - long long int baniol - (long long int * mode, long long int * start, long long int *newpos, - long long int * size, long long int * no, - long long int * nactual, long long int * fdes, const char *fname, - char *datary, - long long int namelen ) { -#endif - int i, j, jret, seekret; - char *realname; - int tcharval; - size_t count; - -/* Initialization(s) */ - *nactual = 0; - -/* Check for illegal combinations of options */ - if (( BAOPEN_RONLY & *mode) && - ( (BAOPEN_WONLY & *mode) || (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) ) ) { - #ifdef VERBOSE - printf("illegal -- trying to open both read only and write only\n"); - #endif - return 255; - } - if ( (BAREAD & *mode ) && (BAWRITE & *mode) ) { - #ifdef VERBOSE - printf("illegal -- trying to both read and write in the same call\n"); - #endif - return 254; - } - -/* This section handles Fortran to C translation of strings so as to */ -/* be able to open the files Fortran is expecting to be opened. */ - #ifdef CRAY90 - namelen = _fcdlen(fcd_fname); - fname = _fcdtocp(fcd_fname); - #endif - if ( (BAOPEN_RONLY & *mode) || (BAOPEN_WONLY & *mode) || - (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) || - (BAOPEN_RW & *mode) ) { - #ifdef VERBOSE - printf("Will be opening a file %s %d\n", fname, namelen); fflush(stdout); - printf("Strlen %d namelen %d\n", strlen(fname), namelen); fflush(stdout); - #endif - realname = (char *) malloc( (namelen+1) * sizeof(char) ) ; - if (realname == NULL) { - #ifdef VERBOSE - printf("failed to mallocate realname %d = namelen\n", namelen); - fflush(stdout); - #endif - return 253; - } - i=0; - while (i < namelen && isgraph(fname[i])) { - realname[i]=fname[i]; - i++; - } - realname[i] = '\0'; - - } - -/* Open files with correct read/write and file permission. */ - if (BAOPEN_RONLY & *mode) { - #ifdef VERBOSE - printf("open read only %s\n", realname); - #endif - *fdes = open(realname, O_RDONLY , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY & *mode ) { - #ifdef VERBOSE - printf("open write only %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY_TRUNC & *mode ) { - #ifdef VERBOSE - printf("open write only with truncation %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT | O_TRUNC , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_WONLY_APPEND & *mode ) { - #ifdef VERBOSE - printf("open write only with append %s\n", realname); - #endif - *fdes = open(realname, O_WRONLY | O_CREAT | O_APPEND , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else if (BAOPEN_RW & *mode) { - #ifdef VERBOSE - printf("open read-write %s\n", realname); - #endif - *fdes = open(realname, O_RDWR | O_CREAT , S_IRUSR | S_IRGRP | S_IROTH | S_IWUSR | S_IWGRP ); - } - else { - #ifdef VERBOSE - printf("no openings\n"); - #endif - } - if (*fdes < 0) { - #ifdef VERBOSE - printf("error in file descriptor! *fdes %d\n", *fdes); - #endif - return 252; - } - else { - #ifdef VERBOSE - printf("file descriptor = %d\n",*fdes ); - #endif - } - - -/* Read data as requested */ - if (BAREAD & *mode && - ( (BAOPEN_WONLY & *mode) || (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) ) ) { - #ifdef VERBOSE - printf("Error, trying to read while in write only mode!\n"); - #endif - return 251; - } - else if (BAREAD & *mode ) { - /* Read in some data */ - if (! (*mode & NOSEEK) ) { - seekret = lseek(*fdes, *start, SEEK_SET); - if (seekret == -1) { - #ifdef VERBOSE - printf("error in seeking to %d\n",*start); - #endif - return 250; - } - #ifdef VERBOSE - else { - printf("Seek successful, seek ret %d, start %d\n", seekret, *start); - } - #endif - } - jret = read(*fdes, datary, *no*(*size) ); - if (jret != *no*(*size) ) { - #ifdef VERBOSE - printf("did not read in the requested number of items\n"); - printf("read in %d items of %d \n",jret/(*size), *no); - #endif - *nactual = jret/(*size); - *newpos = *start + jret; - } - #ifdef VERBOSE - printf("read in %d items \n", jret/(*size)); - #endif - *nactual = jret/(*size); - *newpos = *start + jret; - } -/* Done with reading */ - -/* See if we should be writing */ - if ( BAWRITE & *mode && BAOPEN_RONLY & *mode ) { - #ifdef VERBOSE - printf("Trying to write on a read only file \n"); - #endif - return 249; - } - else if ( BAWRITE & *mode ) { - if (! (*mode & NOSEEK) ) { - seekret = lseek(*fdes, *start, SEEK_SET); - if (seekret == -1) { - #ifdef VERBOSE - printf("error in seeking to %d\n",*start); - #endif - return 248; - } - #ifdef VERBOSE - else { - printf("Seek successful, seek ret %d, start %d\n", seekret, *start); - } - #endif - } - jret = write(*fdes, datary, *no*(*size)); - if (jret != *no*(*size)) { - #ifdef VERBOSE - printf("did not write out the requested number of items\n"); - printf("wrote %d items instead\n", jret/(*size) ); - #endif - *nactual = jret/(*size) ; - *newpos = *start + jret; - } - else { - #ifdef VERBOSE - printf("wrote %d items \n", jret/(*size) ); - #endif - *nactual = jret/(*size) ; - *newpos = *start + jret; - } - } -/* Done with writing */ - - -/* Close file if requested */ - if (BACLOSE & *mode ) { - jret = close(*fdes); - if (jret != 0) { - #ifdef VERBOSE - printf("close failed! jret = %d\n",jret); - #endif - return 247; - } - } -/* Done closing */ - -/* Free the realname pointer to prevent memory leak */ - if ( (BAOPEN_RONLY & *mode) || (BAOPEN_WONLY & *mode) || - (BAOPEN_WONLY_TRUNC & *mode) || (BAOPEN_WONLY_APPEND & *mode) || - (BAOPEN_RW & *mode) ) { - free(realname); - } - -/* Check that if we were reading or writing, that we actually got what */ -/* we expected, else return a -10. Return 0 (success) if we're here */ -/* and weren't reading or writing */ - if ( (*mode & BAREAD || *mode & BAWRITE) && (*nactual != *no) ) { - return 246; - } - else { - return 0; - } -} diff --git a/external/bacio/v2.0.1/src/baciof.f b/external/bacio/v2.0.1/src/baciof.f deleted file mode 100644 index 0412013ae..000000000 --- a/external/bacio/v2.0.1/src/baciof.f +++ /dev/null @@ -1,730 +0,0 @@ -C----------------------------------------------------------------------- - MODULE BACIO_MODULE -C$$$ F90-MODULE DOCUMENTATION BLOCK -C -C F90-MODULE: BACIO_MODULE BYTE-ADDRESSABLE I/O MODULE -C PRGMMR: IREDELL ORG: NP23 DATE: 98-06-04 -C -C ABSTRACT: MODULE TO SHARE FILE DESCRIPTORS -C IN THE BYTE-ADDESSABLE I/O PACKAGE. -C -C PROGRAM HISTORY LOG: -C 98-06-04 IREDELL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - INTEGER,EXTERNAL:: BACIO,BACIOL - INTEGER,PARAMETER :: FDDIM=9999 - INTEGER,DIMENSION(FDDIM),SAVE:: FD=FDDIM*0 - INTEGER,DIMENSION(20),SAVE:: BAOPTS=0 - INCLUDE 'baciof.h' - END -C----------------------------------------------------------------------- - SUBROUTINE BASETO(NOPT,VOPT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BASETO BYTE-ADDRESSABLE SET OPTIONS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: SET OPTIONS FOR BYTE-ADDRESSABLE I/O. -C ALL OPTIONS DEFAULT TO 0. -C OPTION 1: BLOCKED READING OPTION -C IF THE OPTION VALUE IS 1, THEN THE READING IS BLOCKED -C INTO FOUR 4096-BYTE BUFFERS. THIS MAY BE EFFICIENT IF -C THE READS WILL BE REQUESTED IN MUCH SMALLER CHUNKS. -C OTHERWISE, EACH CALL TO BAREAD INITIATES A PHYSICAL READ. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C -C USAGE: CALL BASETO(NOPT,VOPT) -C INPUT ARGUMENTS: -C NOPT INTEGER OPTION NUMBER -C VOPT INTEGER OPTION VALUE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE - INTEGER NOPT,VOPT -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(NOPT.GE.1.AND.NOPT.LE.20) BAOPTS(NOPT)=VOPT -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END -C----------------------------------------------------------------------- - SUBROUTINE BAOPEN(LU,CFN,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAOPEN BYTE-ADDRESSABLE OPEN -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: OPEN A BYTE-ADDRESSABLE FILE. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C -C USAGE: CALL BAOPEN(LU,CFN,IRET) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO OPEN -C CFN CHARACTER FILENAME TO OPEN -C (CONSISTING OF NONBLANK PRINTABLE CHARACTERS) -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIO BYTE-ADDRESSABLE I/O C PACKAGE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE - CHARACTER CFN*(*) - CHARACTER(80) CMSG - integer(kind=8) IB,JB,NB,KA -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(LU.LT.001.OR.LU.GT.FDDIM) THEN - IRET=6 - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IRET=BACIOL(BACIO_OPENRW,IB,JB,1,NB,KA,FD(LU),CFN,A) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END -C----------------------------------------------------------------------- - SUBROUTINE BAOPENR(LU,CFN,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAOPENR BYTE-ADDRESSABLE OPEN -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: OPEN A BYTE-ADDRESSABLE FILE FOR READ ONLY. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C -C USAGE: CALL BAOPENR(LU,CFN,IRET) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO OPEN -C CFN CHARACTER FILENAME TO OPEN -C (CONSISTING OF NONBLANK PRINTABLE CHARACTERS) -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIO BYTE-ADDRESSABLE I/O C PACKAGE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE - CHARACTER CFN*(*) - INTEGER LU,iret - integer(kind=8) IB,JB,NB,KA -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(LU.LT.001.OR.LU.GT.FDDIM) THEN - IRET=6 - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IRET=BACIOL(BACIO_OPENR,IB,JB,1,NB,KA,FD(LU),CFN,A) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END -C----------------------------------------------------------------------- - SUBROUTINE BAOPENW(LU,CFN,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAOPENW BYTE-ADDRESSABLE OPEN -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: OPEN A BYTE-ADDRESSABLE FILE FOR WRITE ONLY. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C -C USAGE: CALL BAOPENW(LU,CFN,IRET) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO OPEN -C CFN CHARACTER FILENAME TO OPEN -C (CONSISTING OF NONBLANK PRINTABLE CHARACTERS) -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIO BYTE-ADDRESSABLE I/O C PACKAGE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE - CHARACTER CFN*(*) - integer(kind=8) IB,JB,NB,KA -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(LU.LT.001.OR.LU.GT.FDDIM) THEN - IRET=6 - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IRET=BACIOL(BACIO_OPENW,IB,JB,1,NB,KA,FD(LU),CFN,A) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END -C----------------------------------------------------------------------- - SUBROUTINE BAOPENWT(LU,CFN,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAOPENWT BYTE-ADDRESSABLE OPEN -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: OPEN A BYTE-ADDRESSABLE FILE FOR WRITE ONLY WITH TRUNCATION. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C -C USAGE: CALL BAOPENWT(LU,CFN,IRET) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO OPEN -C CFN CHARACTER FILENAME TO OPEN -C (CONSISTING OF NONBLANK PRINTABLE CHARACTERS) -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIO BYTE-ADDRESSABLE I/O C PACKAGE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE - CHARACTER CFN*(*) - integer(kind=8) IB,JB,NB,KA -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(LU.LT.001.OR.LU.GT.FDDIM) THEN - IRET=6 - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IRET=BACIOL(BACIO_OPENWT,IB,JB,1,NB,KA,FD(LU),CFN,A) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END -C----------------------------------------------------------------------- - SUBROUTINE BAOPENWA(LU,CFN,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAOPENWA BYTE-ADDRESSABLE OPEN -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: OPEN A BYTE-ADDRESSABLE FILE FOR WRITE ONLY WITH APPEND. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C -C USAGE: CALL BAOPENWA(LU,CFN,IRET) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO OPEN -C CFN CHARACTER FILENAME TO OPEN -C (CONSISTING OF NONBLANK PRINTABLE CHARACTERS) -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIO BYTE-ADDRESSABLE I/O C PACKAGE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE - CHARACTER CFN*(*) - integer(kind=8) IB,JB,NB,KA -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(LU.LT.001.OR.LU.GT.FDDIM) THEN - IRET=6 - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IRET=BACIOL(BACIO_OPENWA,IB,JB,1,NB,KA,FD(LU),CFN,A) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END -C----------------------------------------------------------------------- - SUBROUTINE BACLOSE(LU,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BACLOSE BYTE-ADDRESSABLE CLOSE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: CLOSE A BYTE-ADDRESSABLE FILE. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C -C USAGE: CALL BACLOSE(LU,IRET) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO CLOSE -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIO BYTE-ADDRESSABLE I/O C PACKAGE -C -C REMARKS: A BAOPEN MUST HAVE ALREADY BEEN CALLED. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE - integer(kind=8) IB,JB,NB,KA -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(LU.LT.001.OR.LU.GT.FDDIM) THEN - IRET=6 - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IRET=BACIOL(BACIO_CLOSE,IB,JB,1,NB,KA,FD(LU),CHAR(0),A) - IF(IRET.EQ.0) FD(LU)=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END -C----------------------------------------------------------------------- - SUBROUTINE BAREAD(LU,IB,NB,KA,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAREAD BYTE-ADDRESSABLE READ -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: THIS BAREAD IS CALLING BAREADL TO READ A GIVEN NUMBER OF -C BYTES FROM AN UNBLOCKED FILE,SKIPPING A GIVEN NUMBER OF BYTES. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAREAD(LU,IB,NB,KA,A) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO READ -C IB INTEGER NUMBER OF BYTES TO SKIP -C (IF IB<0, THEN THE FILE IS ACCESSED WITH NO SEEKING) -C NB INTEGER NUMBER OF BYTES TO READ -C OUTPUT ARGUMENTS: -C KA INTEGER NUMBER OF BYTES ACTUALLY READ -C A CHARACTER*1 (NB) DATA READ -C -C SUBPROGRAMS CALLED: -C BAREADL BYTE-ADDRESSABLE READ SUBROUTINE -C -C REMARKS: A BAOPEN MUST HAVE ALREADY BEEN CALLED. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -! - IMPLICIT NONE - INTEGER,INTENT(IN) :: LU,IB,NB - INTEGER,INTENT(OUT) :: KA - CHARACTER,INTENT(OUT) :: A(NB) - INTEGER(KIND=8) :: LONG_IB,LONG_NB,LONG_KA -! - if(NB<0 ) THEN - print *,'WRONG: in BAREAD read data size NB < 0, STOP! '// & - & 'Consider using BAREADL and long integer' - KA=0 - return - ENDIF - LONG_IB=IB - LONG_NB=NB - CALL BAREADL(LU,LONG_IB,LONG_NB,LONG_KA,A) - KA=LONG_KA - - END SUBROUTINE BAREAD -C----------------------------------------------------------------------- - SUBROUTINE BAREADL(LU,IB,NB,KA,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAREAD BYTE-ADDRESSABLE READ -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: THIS SUBROUYTINE IS USING UPDATED BACIOL I/O PACKAGE TO READ -C A GIVEN NUMBER OF BYTES FROM AN UNBLOCKED FILE, SKIPPING A GIVEN -C NUMBER OF BYTES. -C THE PHYSICAL I/O IS BLOCKED INTO FOUR 4096-BYTE BUFFERS -C IF THE BYTE-ADDRESSABLE OPTION 1 HAS BEEN SET TO 1 BY BASETO. -C THIS BUFFERED READING IS INCOMPATIBLE WITH NO-SEEK READING. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAREAD(LU,IB,NB,KA,A) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO READ -C IB INTEGER(8) NUMBER OF BYTES TO SKIP -C (IF IB<0, THEN THE FILE IS ACCESSED WITH NO SEEKING) -C NB INTEGER(8) NUMBER OF BYTES TO READ -C OUTPUT ARGUMENTS: -C KA INTEGER(8) NUMBER OF BYTES ACTUALLY READ -C A CHARACTER*1 (NB) DATA READ -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIOL BYTE-ADDRESSABLE I/O C PACKAGE -C -C REMARKS: A BAOPEN MUST HAVE ALREADY BEEN CALLED. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE -! - IMPLICIT NONE - INTEGER,intent(in) :: LU - INTEGER(kind=8),intent(in) :: IB,NB - INTEGER(kind=8),intent(out) :: KA - CHARACTER,intent(out) :: A(NB) - integer(kind=8),PARAMETER :: NY=4096,MY=4 - INTEGER(KIND=8) NS(MY),NN(MY) - INTEGER(kind=8) JB,LONG_0,KY,I,K,IY,JY,LUX - INTEGER IRET -! INTEGER LU,IB,NB,KA - CHARACTER Y(NY,MY) - DATA LUX/0/ - SAVE JY,NS,NN,Y,LUX -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(FD(LU).LE.0) THEN - KA=0 - RETURN - ENDIF - IF(IB.LT.0.AND.BAOPTS(1).EQ.1) THEN - KA=0 - RETURN - ENDIF - IF(NB.LE.0) THEN - KA=0 - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - LONG_0=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C UNBUFFERED I/O - IF(BAOPTS(1).NE.1) THEN - KA=0 - IF(IB.GE.0) THEN - IRET=BACIOL(BACIO_READ,IB,JB,1,NB,KA,FD(LU),CHAR(0),A) - ELSE - IRET=BACIOL(BACIO_READ+BACIO_NOSEEK,LONG_0,JB,1,NB,KA, & - & FD(LU),CHAR(0),A) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C BUFFERED I/O -C GET DATA FROM PREVIOUS CALL IF POSSIBLE - ELSE - KA=0 - IF(LUX.NE.LU) THEN - JY=0 - NS=0 - NN=0 - ELSE - DO I=1,MY - IY=MOD(JY+I-1,MY)+1 - KY=IB+KA-NS(IY) - IF(KA.LT.NB.AND.KY.GE.LONG_0.AND.KY.LT.NN(IY)) THEN - K=MIN(NB-KA,NN(IY)-KY) - A(KA+1:KA+K)=Y(KY+1:KY+K,IY) - KA=KA+K - ENDIF - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SET POSITION AND READ BUFFER AND GET DATA - IF(KA.LT.NB) THEN - LUX=ABS(LU) - JY=MOD(JY,MY)+1 - NS(JY)=IB+KA - IRET=BACIOL(BACIO_READ,NS(JY),JB,1,NY,NN(JY), - & FD(LUX),CHAR(0),Y(1,JY)) - IF(NN(JY).GT.0) THEN - K=MIN(NB-KA,NN(JY)) - A(KA+1:KA+K)=Y(1:K,JY) - KA=KA+K - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CONTINUE TO READ BUFFER AND GET DATA - DOWHILE(NN(JY).EQ.NY.AND.KA.LT.NB) - JY=MOD(JY,MY)+1 - NS(JY)=NS(JY)+NN(JY) - IRET=BACIOL(BACIO_READ+BACIO_NOSEEK,NS(JY),JB,1,NY,NN(JY), - & FD(LUX),CHAR(0),Y(1,JY)) - IF(NN(JY).GT.0) THEN - K=MIN(NB-KA,NN(JY)) - A(KA+1:KA+K)=Y(1:K,JY) - KA=KA+K - ENDIF - ENDDO - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END SUBROUTINE BAREADL -C----------------------------------------------------------------------- - SUBROUTINE BAWRITE(LU,IB,NB,KA,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAWRITE BYTE-ADDRESSABLE WRITE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: THIS PROGRAM IS CALLING BAWRITEL TO WRITE A GIVEN NUMBER OF -C BYTES TO AN UNBLOCKED FILE,SKIPPING A GIVEN NUMBER OF BYTES. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAWRITE(LU,IB,NB,KA,A) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO WRITE -C IB INTEGER NUMBER OF BYTES TO SKIP -C (IF IB<0, THEN THE FILE IS ACCESSED WITH NO SEEKING) -C NB INTEGER NUMBER OF BYTES TO WRITE -C A CHARACTER*1 (NB) DATA TO WRITE -C OUTPUT ARGUMENTS: -C KA INTEGER NUMBER OF BYTES ACTUALLY WRITTEN -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIO BYTE-ADDRESSABLE I/O C PACKAGE -C -C REMARKS: A BAOPEN MUST HAVE ALREADY BEEN CALLED. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -! - IMPLICIT NONE - INTEGER,INTENT(IN) :: LU,IB,NB - INTEGER,INTENT(OUT) :: KA - CHARACTER,INTENT(IN) :: A(NB) - INTEGER(KIND=8) :: LONG_IB,LONG_NB,LONG_KA -! - if(NB<0 ) THEN - print *,'WRONG: in BAWRITE read data size NB <0, STOP! '// & - & 'Consider using BAWRITEL and long integer' - KA=0 - return - ENDIF -! - LONG_IB=IB - LONG_NB=NB - CALL BAWRITEL(LU,LONG_IB,LONG_NB,LONG_KA,A) - KA=LONG_KA - - END SUBROUTINE BAWRITE -C----------------------------------------------------------------------- - SUBROUTINE BAWRITEL(LU,IB,NB,KA,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAWRITEL BYTE-ADDRESSABLE WRITE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: THIS SUBROUYTINE IS USING UPDATED BACIOL I/O PACKAGE TO WRITE -C A GIVEN NUMBER OF BYTES TO AN UNBLOCKED FILE, SKIPPING A GIVEN NUMBER -C OF BYTES. -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAWRITEL(LU,IB,NB,KA,A) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO WRITE -C IB INTEGER(8) NUMBER OF BYTES TO SKIP -C (IF IB<0, THEN THE FILE IS ACCESSED WITH NO SEEKING) -C NB INTEGER(8) NUMBER OF BYTES TO WRITE -C A CHARACTER*1 (NB) DATA TO WRITE -C OUTPUT ARGUMENTS: -C KA INTEGER(8) NUMBER OF BYTES ACTUALLY WRITTEN -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIOL BYTE-ADDRESSABLE I/O C PACKAGE -C -C REMARKS: A BAOPEN MUST HAVE ALREADY BEEN CALLED. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE -! - IMPLICIT NONE -! - INTEGER,intent(in) :: LU - INTEGER(kind=8),intent(in) :: IB,NB - INTEGER(kind=8),intent(out):: KA - CHARACTER,intent(in) :: A(NB) -! - INTEGER(kind=8) :: JB,LONG_0 - INTEGER :: IRET -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(FD(LU).LE.0) THEN - KA=0 - RETURN - ENDIF - IF(NB.LE.0) THEN - KA=0 - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - LONG_0=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(IB.GE.0) THEN - KA=0 - IRET=BACIOL(BACIO_WRITE,IB,JB,1,NB,KA,FD(LU),CHAR(0),A) - ELSE - KA=0 - IRET=BACIOL(BACIO_WRITE+BACIO_NOSEEK,LONG_0,JB,1,NB,KA, & - & FD(LU),CHAR(0),A) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END SUBROUTINE BAWRITEL -C----------------------------------------------------------------------- - SUBROUTINE WRYTE(LU,NB,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: WRYTE WRITE DATA OUT BY BYTES -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: THSI SUBROUTINE IS CALLING WRYTEL TO WRITE A GIVEN NUMBER OF -C BYTES TO AN UNBLOCKED FILE. -C -C PROGRAM HISTORY LOG: -C 92-10-31 IREDELL -C 95-10-31 IREDELL WORKSTATION VERSION -C 1998-06-04 IREDELL BACIO VERSION -C 2009-04-20 J. WANG WRYTEL VERSION -C -C USAGE: CALL WRYTE(LU,NB,A) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO WHICH TO WRITE -C NB INTEGER(4) NUMBER OF BYTES TO WRITE -C A CHARACTER*1 (NB) DATA TO WRITE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIO BYTE-ADDRESSABLE I/O C PACKAGE -C -C REMARKS: A BAOPEN MUST HAVE ALREADY BEEN CALLED. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -! - USE BACIO_MODULE -! - IMPLICIT NONE -! - INTEGER,intent(in) :: LU - INTEGER,intent(in) :: NB - CHARACTER,intent(in) :: A(NB) - INTEGER(kind=8) :: LONG_NB -! - IF(NB<0) THEN - PRINT *,'WRONG: NB: the number of bytes to write <0, STOP!' - RETURN - ENDIF - LONG_NB=NB - CALL WRYTEL(LU,LONG_NB,A) -! - END SUBROUTINE WRYTE -C----------------------------------------------------------------------- - SUBROUTINE WRYTEL(LU,NB,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: WRYTE WRITE DATA OUT BY BYTES -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1998-06-04 -C -C ABSTRACT: WRITE A GIVEN NUMBER OF BYTES TO AN UNBLOCKED FILE. -C -C PROGRAM HISTORY LOG: -C 92-10-31 IREDELL -C 95-10-31 IREDELL WORKSTATION VERSION -C 1998-06-04 IREDELL BACIO VERSION -C 2009-04-20 J. WANG BACIOL VERSION -C -C USAGE: CALL WRYTE(LU,NB,A) -C INPUT ARGUMENTS: -C LU INTEGER UNIT TO WHICH TO WRITE -C NB INTEGER(8) NUMBER OF BYTES TO WRITE -C A CHARACTER*1 (NB) DATA TO WRITE -C -C MODULES USED: -C BACIO_MODULE BYTE-ADDRESSABLE I/O FORTRAN INTERFACE -C -C SUBPROGRAMS CALLED: -C BACIOL BYTE-ADDRESSABLE I/O C PACKAGE -C -C REMARKS: A BAOPEN MUST HAVE ALREADY BEEN CALLED. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - USE BACIO_MODULE -! - IMPLICIT NONE - INTEGER,intent(in) :: LU - INTEGER(kind=8),intent(in) :: NB - CHARACTER,INTENT(in) :: A(NB) - INTEGER(kind=8) :: LONG_0,JB,KA - INTEGER :: IRET -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(FD(LU).LE.0) THEN - RETURN - ENDIF - IF(NB.LE.0) THEN - RETURN - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - LONG_0=0 - KA=0 - JB=0 - IRET=BACIOL(BACIO_WRITE+BACIO_NOSEEK,LONG_0,JB,1,NB,KA, & - & FD(LU),CHAR(0),A) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/bacio/v2.0.1/src/baciof.h b/external/bacio/v2.0.1/src/baciof.h deleted file mode 100644 index 4153e27dc..000000000 --- a/external/bacio/v2.0.1/src/baciof.h +++ /dev/null @@ -1,11 +0,0 @@ -! Include file to define variables for Fortran to C interface(s) -! Robert Grumbine 16 March 1998 - INTEGER,PARAMETER:: BACIO_OPENR=1 ! Open file for read only - INTEGER,PARAMETER:: BACIO_OPENW=2 ! Open file for write only - INTEGER,PARAMETER:: BACIO_OPENRW=4 ! Open file for read or write - INTEGER,PARAMETER:: BACIO_CLOSE=8 ! Close file - INTEGER,PARAMETER:: BACIO_READ=16 ! Read from the file - INTEGER,PARAMETER:: BACIO_WRITE=32 ! Write to the file - INTEGER,PARAMETER:: BACIO_NOSEEK=64 ! Start I/O from previous spot - INTEGER,PARAMETER:: BACIO_OPENWT=128 ! Open for write only with truncation - INTEGER,PARAMETER:: BACIO_OPENWA=256 ! Open for write only with append diff --git a/external/bacio/v2.0.1/src/bafrio.f b/external/bacio/v2.0.1/src/bafrio.f deleted file mode 100644 index 0a29a7ad5..000000000 --- a/external/bacio/v2.0.1/src/bafrio.f +++ /dev/null @@ -1,427 +0,0 @@ -C----------------------------------------------------------------------- -! -! revision history: -! -! Aug, 2012 Jun Wang bafrio for big and little endian files -! -! note: -! This version of bafrio.f is revised to have byteswap in FORTRAN -! data file control words. It is designed to be run on -! on WCOSS(little endian machine) and to generate big endian files. -! It does byteswap on fortran record control words(4 byte integer -! before and after data field), not on data field itself. Users need -! to byteswap their data after(for reading)/before(for writing) -! calling subroutines this file. This is considered to be the best -! way to keep subroutine inerfaces intact for backward compatible. -! -C----------------------------------------------------------------------- - SUBROUTINE BAFRINDEX(LU,IB,LX,IX) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAFRINDEX BYTE-ADDRESSABLE FORTRAN RECORD INDEX -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1999-01-21 -C -C ABSTRACT: THIS SUBPROGRAM IS CALLING BAFRINDEXL TO EITHER READ AN -C UNFORMATTED FORTRAN RECORD -C AND RETURN ITS LENGTH AND START BYTE OF THE NEXT FORTRAN RECORD; -C OR GIVEN THE RECORD LENGTH, WITHOUT I/O IT DETERMINES THE START BYTE -C OF THE NEXT FORTRAN RECORD. THE DIFFERENCE BETWEEN BAFRINDEX AND -C BAFRINDEXL IS THE KIND TYPE OF INTERGERS IN THE ARGUMENT LIST -C -C PROGRAM HISTORY LOG: -C 1999-01-21 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAFRINDEX(LU,IB,LX,IX) -C INPUT ARGUMENTS: -C LU INTEGER LOGICAL UNIT TO READ -C IF LU<=0, THEN DETERMINE IX FROM LX -C IB INTEGER FORTRAN RECORD START BYTE -C (FOR THE FIRST FORTRAN RECORD, IB SHOULD BE 0) -C LX INTEGER RECORD LENGTH IN BYTES IF LU<=0 -C -C OUTPUT ARGUMENTS: -C LX INTEGER RECORD LENGTH IN BYTES IF LU>0, -C OR LX=-1 FOR I/O ERROR (PROBABLE END OF FILE), -C OR LX=-2 FOR I/O ERROR (INVALID FORTRAN RECORD) -C IX INTEGER START BYTE FOR THE NEXT FORTRAN RECORD -C (COMPUTED ONLY IF LX>=0) -C -C SUBPROGRAMS CALLED: -C BAFRINDEXL BYTE-ADDRESSABLE FORTRAN RECORD INDEX -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -! - IMPLICIT NONE - INTEGER,INTENT(IN):: LU,IB - INTEGER,INTENT(INOUT):: LX - INTEGER,INTENT(OUT):: IX - integer(kind=8) :: LONG_IB,LONG_LX ,LONG_IX -! - LONG_IB=IB - LONG_LX=LX - call BAFRINDEXL(LU,LONG_IB,LONG_LX,LONG_IX) - LX=LONG_LX - IX=LONG_IX - - return - end SUBROUTINE BAFRINDEX -C----------------------------------------------------------------------- - SUBROUTINE BAFRINDEXL(LU,IB,LX,IX) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAFRINDEXL BYTE-ADDRESSABLE FORTRAN RECORD INDEX -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1999-01-21 -C -C ABSTRACT: THIS SUBPROGRAM EITHER READS AN UNFORMATTED FORTRAN RECORD -C AND RETURN ITS LENGTH AND START BYTE OF THE NEXT FORTRAN RECORD; -C OR GIVEN THE RECORD LENGTH, WITHOUT I/O IT DETERMINES THE START BYTE -C OF THE NEXT FORTRAN RECORD. -C -C PROGRAM HISTORY LOG: -C 1999-01-21 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAFRINDEXL(LU,IB,LX,IX) -C INPUT ARGUMENTS: -C LU INTEGER LOGICAL UNIT TO READ -C IF LU<=0, THEN DETERMINE IX FROM LX -C IB INTEGER(8) FORTRAN RECORD START BYTE -C (FOR THE FIRST FORTRAN RECORD, IB SHOULD BE 0) -C LX INTEGER(8) RECORD LENGTH IN BYTES IF LU<=0 -C -C OUTPUT ARGUMENTS: -C LX INTEGER(8) RECORD LENGTH IN BYTES IF LU>0, -C OR LX=-1 FOR I/O ERROR (PROBABLE END OF FILE), -C OR LX=-2 FOR I/O ERROR (INVALID FORTRAN RECORD) -C IX INTEGER(8) START BYTE FOR THE NEXT FORTRAN RECORD -C (COMPUTED ONLY IF LX>=0) -C -C SUBPROGRAMS CALLED: -C BAREADL BYTE-ADDRESSABLE READ -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: LU - INTEGER(KIND=8),INTENT(IN):: IB - INTEGER(KIND=8),INTENT(INOUT):: LX - INTEGER(KIND=8),INTENT(OUT):: IX - INTEGER(KIND=8),PARAMETER:: LBCW=4 - INTEGER(KIND=LBCW):: BCW1,BCW2 - INTEGER(KIND=8):: KR - CHARACTER(16) :: MACHINE_ENDIAN - LOGICAL :: DO_BYTESWAP -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPARE FIRST BLOCK CONTROL WORD AND TRAILING BLOCK CONTROL WORD - IF(LU.GT.0) THEN -! -!-- set do_byteswap from machine endianness and file endianness - CALL CHK_ENDIANC(MACHINE_ENDIAN) - IF( LU<=999) THEN - IF( trim(MACHINE_ENDIAN)=="big_endian") THEN - DO_BYTESWAP=.false. - ELSEIF( trim(MACHINE_ENDIAN)=="little_endian") THEN - DO_BYTESWAP=.true. - ENDIF - ELSEIF(LU<=1999) THEN - IF( trim(MACHINE_ENDIAN)=="big_endian") THEN - DO_BYTESWAP=.true. - ELSEIF( trim(MACHINE_ENDIAN)=="little_endian") THEN - DO_BYTESWAP=.false. - ENDIF - ENDIF -! -! -!-- read out control word - CALL BAREADL(LU,IB,LBCW,KR,BCW1) - IF(DO_BYTESWAP) CALL Byteswap(BCW1,LBCW,1) -! - IF(KR.NE.LBCW) THEN - LX=-1 - ELSE - CALL BAREADL(LU,IB+LBCW+BCW1,LBCW,KR,BCW2) - IF(DO_BYTESWAP) CALL Byteswap(BCW2,LBCW,1) -! - IF(KR.NE.LBCW.OR.BCW1.NE.BCW2) THEN - LX=-2 - ELSE - LX=BCW1 - ENDIF - ENDIF -! -!end luif - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE START BYTE FOR THE NEXT FORTRAN RECORD - IF(LX.GE.0) IX=IB+LBCW+LX+LBCW -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END SUBROUTINE BAFRINDEXL -C----------------------------------------------------------------------- - SUBROUTINE BAFRREAD(LU,IB,NB,KA,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAFRREAD BYTE-ADDRESSABLE FORTRAN RECORD READ -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1999-01-21 -C -C ABSTRACT: THIS SUBPROGRAM IS CALLING BAFREAD TO REAS AN UNFORMATTED -C FORTRAN RECORD. THE DIFFERENCE BETWEEN BAFRREAD AND BAFRREADL IS -C THE KIND TYPE OF INTERGERS IN THE ARGUMENT LIST -C -C PROGRAM HISTORY LOG: -C 1999-01-21 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAFRREAD(LU,IB,NB,KA,A) -C INPUT ARGUMENTS: -C LU INTEGER LOGICAL UNIT TO READ -C IB INTEGER FORTRAN RECORD START BYTE -C (FOR THE FIRST FORTRAN RECORD, IB SHOULD BE 0) -C NB INTEGER NUMBER OF BYTES TO READ -C -C OUTPUT ARGUMENTS: -C KA INTEGER NUMBER OF BYTES IN FORTRAN RECORD -C (IN WHICH CASE THE NEXT FORTRAN RECORD -C SHOULD HAVE A START BYTE OF IB+KA), -C OR KA=-1 FOR I/O ERROR (PROBABLE END OF FILE), -C OR KA=-2 FOR I/O ERROR (INVALID FORTRAN RECORD), -C OR KA=-3 FOR I/O ERROR (REQUEST LONGER THAN RECORD) -C A CHARACTER*1 (NB) DATA READ -C -C SUBPROGRAMS CALLED: -C BAFRREADL BYTE-ADDRESSABLE READ -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -! - IMPLICIT NONE - INTEGER,INTENT(IN):: LU,IB,NB - INTEGER,INTENT(OUT):: KA - CHARACTER,INTENT(OUT):: A(NB) - INTEGER(KIND=8) :: LONG_IB,LONG_NB,LONG_KA -! - if((IB<0.and.IB/=-1) .or. NB<0 ) THEN - print *,'WRONG: in BAFRREAD starting postion IB or read '// & - & 'data size NB < 0, STOP! Consider use BAFREADL and long integer' - KA=0 - return - ENDIF - LONG_IB=IB - LONG_NB=NB - CALL BAFRREADL(LU,LONG_IB,LONG_NB,LONG_KA,A) - KA=LONG_KA - END SUBROUTINE BAFRREAD -C----------------------------------------------------------------------- - SUBROUTINE BAFRREADL(LU,IB,NB,KA,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAFRREADL BYTE-ADDRESSABLE FORTRAN RECORD READ -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1999-01-21 -C -C ABSTRACT: THIS SUBPROGRAM READS AN UNFORMATTED FORTRAN RECORD -C -C PROGRAM HISTORY LOG: -C 1999-01-21 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAFRREADL(LU,IB,NB,KA,A) -C INPUT ARGUMENTS: -C LU INTEGER LOGICAL UNIT TO READ -C IB INTEGER(8) FORTRAN RECORD START BYTE -C (FOR THE FIRST FORTRAN RECORD, IB SHOULD BE 0) -C NB INTEGER(8) NUMBER OF BYTES TO READ -C -C OUTPUT ARGUMENTS: -C KA INTEGER(8) NUMBER OF BYTES IN FORTRAN RECORD -C (IN WHICH CASE THE NEXT FORTRAN RECORD -C SHOULD HAVE A START BYTE OF IB+KA), -C OR KA=-1 FOR I/O ERROR (PROBABLE END OF FILE), -C OR KA=-2 FOR I/O ERROR (INVALID FORTRAN RECORD), -C OR KA=-3 FOR I/O ERROR (REQUEST LONGER THAN RECORD) -C A CHARACTER*1 (NB) DATA READ -C -C SUBPROGRAMS CALLED: -C BAFRINDEXL BYTE-ADDRESSABLE FORTRAN RECORD INDEX -C BAREADL BYTE-ADDRESSABLE READ -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: LU - INTEGER(kind=8),INTENT(IN):: IB,NB - INTEGER(kind=8),INTENT(OUT):: KA - CHARACTER,INTENT(OUT):: A(NB) - INTEGER(kind=8),PARAMETER:: LBCW=4 - INTEGER(kind=8):: LX,IX - INTEGER(kind=8):: KR -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C VALIDATE FORTRAN RECORD - CALL BAFRINDEXL(LU,IB,LX,IX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ IF VALID - IF(LX.LT.0) THEN - KA=LX - ELSEIF(LX.LT.NB) THEN - KA=-3 - ELSE - CALL BAREADL(LU,IB+LBCW,NB,KR,A) - IF(KR.NE.NB) THEN - KA=-1 - ELSE - KA=LBCW+LX+LBCW - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END SUBROUTINE BAFRREADL -C----------------------------------------------------------------------- - SUBROUTINE BAFRWRITE(LU,IB,NB,KA,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAFRWRITE BYTE-ADDRESSABLE FORTRAN RECORD WRITE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1999-01-21 -C -C ABSTRACT: THIS SUBPROGRAM IS CALLING BAFRWRITE TO WRITE AN UNFORMATTED -C FORTRAN RECORD. THE DIFFERENCE BETWEEN BAFRWRITE AND BAFRWRITEL IS -C THE KIND TYPE OF INTERGERS IN THE ARGUMENT LIST -C -C PROGRAM HISTORY LOG: -C 1999-01-21 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAFRWRITE(LU,IB,NB,KA,A) -C INPUT ARGUMENTS: -C LU INTEGER LOGICAL UNIT TO WRITE -C IB INTEGER FORTRAN RECORD START BYTE -C (FOR THE FIRST FORTRAN RECORD, IB SHOULD BE 0) -C NB INTEGER NUMBER OF BYTES TO WRITE -C A CHARACTER*1 (NB) DATA TO WRITE -C -C OUTPUT ARGUMENTS: -C KA INTEGER NUMBER OF BYTES IN FORTRAN RECORD -C (IN WHICH CASE THE NEXT FORTRAN RECORD -C SHOULD HAVE A START BYTE OF IB+KA), -C OR KA=-1 FOR I/O ERROR -C -C SUBPROGRAMS CALLED: -C BAWRITEL BYTE-ADDRESSABLE WRITE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - -! - IMPLICIT NONE - INTEGER,INTENT(IN):: LU,IB,NB - INTEGER,INTENT(OUT):: KA - CHARACTER,INTENT(IN):: A(NB) - INTEGER(KIND=8) :: LONG_IB,LONG_NB,LONG_KA -! - if((IB<0.and.IB/=-1) .or. NB<0 ) THEN - print *,'WRONG: in BAFRWRITE starting postion IB or read '// & - & 'data size NB <0, STOP! ' // & - & 'Consider use BAFRRWRITEL and long integer' - KA=0 - return - ENDIF - LONG_IB=IB - LONG_NB=NB - CALL BAFRWRITEL(LU,LONG_IB,LONG_NB,LONG_KA,A) - KA=LONG_KA -! - END SUBROUTINE BAFRWRITE -C----------------------------------------------------------------------- - SUBROUTINE BAFRWRITEL(LU,IB,NB,KA,A) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: BAFRWRITEL BYTE-ADDRESSABLE FORTRAN RECORD WRITE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 1999-01-21 -C -C ABSTRACT: THIS SUBPROGRAM WRITES AN UNFORMATTED FORTRAN RECORD -C -C PROGRAM HISTORY LOG: -C 1999-01-21 IREDELL -C 2009-04-20 J. WANG -C -C USAGE: CALL BAFRWRITEL(LU,IB,NB,KA,A) -C INPUT ARGUMENTS: -C LU INTEGER LOGICAL UNIT TO WRITE -C IB INTEGER(8) FORTRAN RECORD START BYTE -C (FOR THE FIRST FORTRAN RECORD, IB SHOULD BE 0) -C NB INTEGER(8) NUMBER OF BYTES TO WRITE -C A CHARACTER*1 (NB) DATA TO WRITE -C -C OUTPUT ARGUMENTS: -C KA INTEGER(8) NUMBER OF BYTES IN FORTRAN RECORD -C (IN WHICH CASE THE NEXT FORTRAN RECORD -C SHOULD HAVE A START BYTE OF IB+KA), -C OR KA=-1 FOR I/O ERROR -C -C SUBPROGRAMS CALLED: -C BAWRITEL BYTE-ADDRESSABLE WRITE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: LU - INTEGER(KIND=8),INTENT(IN):: IB,NB - INTEGER(kind=8),INTENT(OUT):: KA - CHARACTER,INTENT(IN):: A(NB) -! - INTEGER(kind=8),PARAMETER:: LBCW=4 - INTEGER(kind=LBCW):: BCW - INTEGER(kind=8):: KR - INTEGER(LBCW):: BCW2,LBCW2 - CHARACTER(16) :: MACHINE_ENDIAN - LOGICAL :: DO_BYTESWAP -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C WRITE DATA BRACKETED BY BLOCK CONTROL WORDS -! -!-- set do_byteswap from machine endianness and file endianness - CALL CHK_ENDIANC(MACHINE_ENDIAN) - IF( LU<=999) THEN - IF( trim(MACHINE_ENDIAN)=="big_endian") THEN - DO_BYTESWAP=.false. - ELSEIF( trim(MACHINE_ENDIAN)=="little_endian") THEN - DO_BYTESWAP=.true. - ENDIF - ELSEIF(LU<=1999) THEN - IF( trim(MACHINE_ENDIAN)=="big_endian") THEN - DO_BYTESWAP=.true. - ELSEIF( trim(MACHINE_ENDIAN)=="little_endian") THEN - DO_BYTESWAP=.false. - ENDIF - ENDIF -! -! - BCW=NB - IF(DO_BYTESWAP) CALL Byteswap(BCW,LBCW,1) - CALL BAWRITEL(LU,IB,LBCW,KR,BCW) - IF(KR.NE.LBCW) THEN - KA=-1 - ELSE - CALL BAWRITEL(LU,IB+LBCW,NB,KR,A) - IF(KR.NE.NB) THEN - KA=-1 - ELSE - CALL BAWRITEL(LU,IB+LBCW+NB,LBCW,KR,BCW) - IF(KR.NE.LBCW) THEN - KA=-1 - ELSE - KA=LBCW+NB+LBCW - ENDIF - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END SUBROUTINE BAFRWRITEL diff --git a/external/bacio/v2.0.1/src/byteswap.c b/external/bacio/v2.0.1/src/byteswap.c deleted file mode 100644 index 5e89dae32..000000000 --- a/external/bacio/v2.0.1/src/byteswap.c +++ /dev/null @@ -1,52 +0,0 @@ -/*--------------------------------------------------------------------*/ -/* Documentation block */ -/* */ -/* byteswap: to reverse the order of a sequence of bytes. it takes */ -/* an data array, the number of bytes to swap for each data */ -/* and the number of data elements in the data array to swap, */ -/* then swaps each data element, and returns with swapped data */ -/* Aug 2012 Jun Wang */ -/* input : */ -/* char* data: input data array */ -/* int (or long long int) *nbyte: the number of bytes to swap */ -/* for 4 byte data, the number of bytes is 4 */ -/* for 8 byte data, the number of bytes is 8 */ -/* the maximal number of bytes to swap is 256 */ -/* int *nnum: the number of data elements to swap */ -/* output : */ -/* */ -/* char* data: swappted data array */ -/*--------------------------------------------------------------------*/ - -#ifdef LINUX - void byteswap_ - (char *data, int *nbyte, int *nnum) { -#endif -#ifdef MACOSX - void byteswap_ - (char *data, int *nbyte, int *nnum) { -#endif -#ifdef IBM4 - void byteswap - (char *data, int *nbyte, int *nnum) { -#endif -#ifdef IBM8 - void byteswap - (char *data, long long int *nbyte, long long int *nnum) { -#endif - int i, j; - char swap[256]; - int nb=*nbyte; - int nn=*nnum; - - - for (j=0; j - -/* Do not change things below here yourself */ - -/* IO-related (bacio.c, banio.c) */ -#define BAOPEN_RONLY 1 -#define BAOPEN_WONLY 2 -#define BAOPEN_RW 4 -#define BACLOSE 8 -#define BAREAD 16 -#define BAWRITE 32 -#define NOSEEK 64 -#define BAOPEN_WONLY_TRUNC 128 -#define BAOPEN_WONLY_APPEND 256 diff --git a/external/sp/v2.0.2/src/CMakeLists.txt b/external/sp/v2.0.2/src/CMakeLists.txt deleted file mode 100644 index 7ef8950bd..000000000 --- a/external/sp/v2.0.2/src/CMakeLists.txt +++ /dev/null @@ -1,30 +0,0 @@ -SET(sp_source_code ${SPLIB_SRC}/splat.F - ${SPLIB_SRC}/lapack_gen.F - -) - -if (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - set(f_flags -O3 -fdefault-real-8 -fconvert=big-endian -cpp -DLINUX -fPIC) - # -fp-model strict -real-size 32 -elseif (${CMAKE_Fortran_COMPILER_ID} MATCHES "Intel") - set(f_flags -O3 -auto -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX -fPIC) -elseif (${CMAKE_Fortran_COMPILER_ID} MATCHES "PGI") - set(f_flags -O3 -Mrecursive -i4 -r8 -byteswapio -Kieee -Mpreprocess -DLINUX -fPIC) -else (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - message ("CMAKE_Fortran_COMPILER full path: " ${CMAKE_Fortran_COMPILER}) - message ("Fortran compiler: " ${CMAKE_Fortran_COMPILER_ID}) - message ("This program has only been compiled with gfortran, pgf90 and ifort. If another compiler is needed, the appropriate flags must be added in ${SPLIB_SRC}/CMakeLists.txt") -endif (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - -#add OpenMP -set(c_flags ${c_flags} ${OpenMP_C_FLAGS}) -set(f_flags ${f_flags} ${OpenMP_Fortran_FLAGS}) - -if(${CMAKE_VERSION} LESS 3.3) - string (REPLACE ";" " " f_flags_str "${f_flags}") - SET_SOURCE_FILES_PROPERTIES(${sp_source_code} PROPERTIES COMPILE_FLAGS ${f_flags_str}) -else(${CMAKE_VERSION} LESS 3.3) - add_compile_options("$<$:${f_flags}>") -endif (${CMAKE_VERSION} LESS 3.3) - -ADD_LIBRARY(sp STATIC ${sp_source_code}) diff --git a/external/sp/v2.0.2/src/Makefile b/external/sp/v2.0.2/src/Makefile deleted file mode 100644 index 5c756bf07..000000000 --- a/external/sp/v2.0.2/src/Makefile +++ /dev/null @@ -1,63 +0,0 @@ -#sp Makefile - -############################################################### -# -# AUTHOR: Vuong - W/NP11 -# -# DATE: 12/04/2000 -# -# PURPOSE: This script uses the make utility to update the libsp -# archive libraries. -# It first reads a list of source files in the library and -# then generates a makefile used to update the archive -# libraries. The make command is then executed for each -# archive library, where the archive library name and -# compilation flags are passed to the makefile through -# environment variables. -# -# REMARKS: Only source files that have been modified since the last -# library update are recompiled and replaced in the object -# archive libraries. The make utility determines this -# from the file modification times. -# -# New source files are also compiled and added to the object -# archive libraries -# -# 11-29-12 Mirvis: Added Intel comp, optimization and OMP flags -# and libsp_*g.a builds -# -# 05-29-14 Mirvis: Updated to ver 2.0.2 -############################################################### - -# -# Generate a list of object files that corresponds to the -# list of Fortran ( .f ) files in the current directory - -# Set flags for Double Precision (Size of Real 8-byte and default Integer) version -# of libsp_d.a - -include ../../../../macros.make - -FC = $(FCserial) -SRCS = $(wildcard *.f *.F) -OBJS = $(addsuffix .o, $(basename $(SRCS))) -LIB = ../../../../libsp_v2.0.2_d.a -# libsp_v2.0.2_d.a -FFLAGS = $(SP_FFLAGS) -AFLAGS = $(SP_ARFLAGS) - -$(LIB): $(OBJS) - $(AR) $(AFLAGS) $@ $^ - -.f.a: - $(FC) -c $(FFLAGS) $< - $(AR) $(AFLAGS) $@ $*.o - $(RM) $*.o - -.F.a: - $(FC) -c $(FFLAGS) $< - $(AR) $(AFLAGS) $@ $*.o - $(RM) $*.o - -clean: - $(RM) *.o *.mod $(LIB) diff --git a/external/sp/v2.0.2/src/comp_list b/external/sp/v2.0.2/src/comp_list deleted file mode 100644 index fdfc58206..000000000 --- a/external/sp/v2.0.2/src/comp_list +++ /dev/null @@ -1,660 +0,0 @@ -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spanaly.f -ar -ruv ../splib_v2/libsp_4.a spanaly.o -r - spanaly.o -rm -f spanaly.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spdz2uv.f -ar -ruv ../splib_v2/libsp_4.a spdz2uv.o -r - spdz2uv.o -rm -f spdz2uv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX speps.f -ar -ruv ../splib_v2/libsp_4.a speps.o -r - speps.o -rm -f speps.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spfft1.f -ar -ruv ../splib_v2/libsp_4.a spfft1.o -r - spfft1.o -rm -f spfft1.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spffte.f -ar -ruv ../splib_v2/libsp_4.a spffte.o -r - spffte.o -rm -f spffte.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spfft.f -ar -ruv ../splib_v2/libsp_4.a spfft.o -r - spfft.o -rm -f spfft.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spfftpt.f -ar -ruv ../splib_v2/libsp_4.a spfftpt.o -r - spfftpt.o -rm -f spfftpt.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spgradq.f -ar -ruv ../splib_v2/libsp_4.a spgradq.o -r - spgradq.o -rm -f spgradq.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spgradx.f -ar -ruv ../splib_v2/libsp_4.a spgradx.o -r - spgradx.o -rm -f spgradx.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spgrady.f -ar -ruv ../splib_v2/libsp_4.a spgrady.o -r - spgrady.o -rm -f spgrady.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX splaplac.f -ar -ruv ../splib_v2/libsp_4.a splaplac.o -r - splaplac.o -rm -f splaplac.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX splegend.f -ar -ruv ../splib_v2/libsp_4.a splegend.o -r - splegend.o -rm -f splegend.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sppad.f -ar -ruv ../splib_v2/libsp_4.a sppad.o -r - sppad.o -rm -f sppad.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spsynth.f -ar -ruv ../splib_v2/libsp_4.a spsynth.o -r - spsynth.o -rm -f spsynth.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptezd.f -ar -ruv ../splib_v2/libsp_4.a sptezd.o -r - sptezd.o -rm -f sptezd.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptez.f -ar -ruv ../splib_v2/libsp_4.a sptez.o -r - sptez.o -rm -f sptez.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptezmd.f -ar -ruv ../splib_v2/libsp_4.a sptezmd.o -r - sptezmd.o -rm -f sptezmd.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptezm.f -ar -ruv ../splib_v2/libsp_4.a sptezm.o -r - sptezm.o -rm -f sptezm.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptezmv.f -ar -ruv ../splib_v2/libsp_4.a sptezmv.o -r - sptezmv.o -rm -f sptezmv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptezv.f -ar -ruv ../splib_v2/libsp_4.a sptezv.o -r - sptezv.o -rm -f sptezv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgpmd.f -ar -ruv ../splib_v2/libsp_4.a sptgpmd.o -r - sptgpmd.o -rm -f sptgpmd.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgpm.f -ar -ruv ../splib_v2/libsp_4.a sptgpm.o -r - sptgpm.o -rm -f sptgpm.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgpmv.f -ar -ruv ../splib_v2/libsp_4.a sptgpmv.o -r - sptgpmv.o -rm -f sptgpmv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgpsd.f -ar -ruv ../splib_v2/libsp_4.a sptgpsd.o -r - sptgpsd.o -rm -f sptgpsd.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgps.f -ar -ruv ../splib_v2/libsp_4.a sptgps.o -r - sptgps.o -rm -f sptgps.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgpsv.f -ar -ruv ../splib_v2/libsp_4.a sptgpsv.o -r - sptgpsv.o -rm -f sptgpsv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgptd.f -ar -ruv ../splib_v2/libsp_4.a sptgptd.o -r - sptgptd.o -rm -f sptgptd.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgpt.f -ar -ruv ../splib_v2/libsp_4.a sptgpt.o -r - sptgpt.o -rm -f sptgpt.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgptsd.f -ar -ruv ../splib_v2/libsp_4.a sptgptsd.o -r - sptgptsd.o -rm -f sptgptsd.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgptvd.f -ar -ruv ../splib_v2/libsp_4.a sptgptvd.o -r - sptgptvd.o -rm -f sptgptvd.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptgptv.f -ar -ruv ../splib_v2/libsp_4.a sptgptv.o -r - sptgptv.o -rm -f sptgptv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrand.f -ar -ruv ../splib_v2/libsp_4.a sptrand.o -r - sptrand.o -rm -f sptrand.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptran.f -ar -ruv ../splib_v2/libsp_4.a sptran.o -r - sptran.o -rm -f sptran.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptranf0.f -ar -ruv ../splib_v2/libsp_4.a sptranf0.o -r - sptranf0.o -rm -f sptranf0.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptranf1.f -ar -ruv ../splib_v2/libsp_4.a sptranf1.o -r - sptranf1.o -rm -f sptranf1.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptranf.f -ar -ruv ../splib_v2/libsp_4.a sptranf.o -r - sptranf.o -rm -f sptranf.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptranfv.f -ar -ruv ../splib_v2/libsp_4.a sptranfv.o -r - sptranfv.o -rm -f sptranfv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptranv.f -ar -ruv ../splib_v2/libsp_4.a sptranv.o -r - sptranv.o -rm -f sptranv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrund.f -ar -ruv ../splib_v2/libsp_4.a sptrund.o -r - sptrund.o -rm -f sptrund.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrun.f -ar -ruv ../splib_v2/libsp_4.a sptrun.o -r - sptrun.o -rm -f sptrun.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrung.f -ar -ruv ../splib_v2/libsp_4.a sptrung.o -r - sptrung.o -rm -f sptrung.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrungv.f -ar -ruv ../splib_v2/libsp_4.a sptrungv.o -r - sptrungv.o -rm -f sptrungv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrunl.f -ar -ruv ../splib_v2/libsp_4.a sptrunl.o -r - sptrunl.o -rm -f sptrunl.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrunm.f -ar -ruv ../splib_v2/libsp_4.a sptrunm.o -r - sptrunm.o -rm -f sptrunm.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrunmv.f -ar -ruv ../splib_v2/libsp_4.a sptrunmv.o -r - sptrunmv.o -rm -f sptrunmv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptruns.f -ar -ruv ../splib_v2/libsp_4.a sptruns.o -r - sptruns.o -rm -f sptruns.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrunsv.f -ar -ruv ../splib_v2/libsp_4.a sptrunsv.o -r - sptrunsv.o -rm -f sptrunsv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX sptrunv.f -ar -ruv ../splib_v2/libsp_4.a sptrunv.o -r - sptrunv.o -rm -f sptrunv.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spuv2dz.f -ar -ruv ../splib_v2/libsp_4.a spuv2dz.o -r - spuv2dz.o -rm -f spuv2dz.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spvar.f -ar -ruv ../splib_v2/libsp_4.a spvar.o -r - spvar.o -rm -f spvar.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX spwget.f -ar -ruv ../splib_v2/libsp_4.a spwget.o -r - spwget.o -rm -f spwget.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX fftpack.F -ar -ruv ../splib_v2/libsp_4.a fftpack.o -r - fftpack.o -rm -f fftpack.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX lapack_gen.F -ar -ruv ../splib_v2/libsp_4.a lapack_gen.o -r - lapack_gen.o -rm -f lapack_gen.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX ncpus.F -ar -ruv ../splib_v2/libsp_4.a ncpus.o -r - ncpus.o -rm -f ncpus.o -ifort -c -O3 -auto -openmp -i4 -convert big_endian -assume byterecl -fp-model strict -real-size 32 -fpp -DLINUX splat.F -ar -ruv ../splib_v2/libsp_4.a splat.o -r - splat.o -rm -f splat.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spanaly.f -ar -ruv ../splib_v2/libsp_8.a spanaly.o -r - spanaly.o -rm -f spanaly.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spdz2uv.f -ar -ruv ../splib_v2/libsp_8.a spdz2uv.o -r - spdz2uv.o -rm -f spdz2uv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX speps.f -ar -ruv ../splib_v2/libsp_8.a speps.o -r - speps.o -rm -f speps.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spfft1.f -ar -ruv ../splib_v2/libsp_8.a spfft1.o -r - spfft1.o -rm -f spfft1.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spffte.f -ar -ruv ../splib_v2/libsp_8.a spffte.o -r - spffte.o -rm -f spffte.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spfft.f -ar -ruv ../splib_v2/libsp_8.a spfft.o -r - spfft.o -rm -f spfft.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spfftpt.f -ar -ruv ../splib_v2/libsp_8.a spfftpt.o -r - spfftpt.o -rm -f spfftpt.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spgradq.f -ar -ruv ../splib_v2/libsp_8.a spgradq.o -r - spgradq.o -rm -f spgradq.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spgradx.f -ar -ruv ../splib_v2/libsp_8.a spgradx.o -r - spgradx.o -rm -f spgradx.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spgrady.f -ar -ruv ../splib_v2/libsp_8.a spgrady.o -r - spgrady.o -rm -f spgrady.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX splaplac.f -ar -ruv ../splib_v2/libsp_8.a splaplac.o -r - splaplac.o -rm -f splaplac.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX splegend.f -ar -ruv ../splib_v2/libsp_8.a splegend.o -r - splegend.o -rm -f splegend.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sppad.f -ar -ruv ../splib_v2/libsp_8.a sppad.o -r - sppad.o -rm -f sppad.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spsynth.f -ar -ruv ../splib_v2/libsp_8.a spsynth.o -r - spsynth.o -rm -f spsynth.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezd.f -ar -ruv ../splib_v2/libsp_8.a sptezd.o -r - sptezd.o -rm -f sptezd.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptez.f -ar -ruv ../splib_v2/libsp_8.a sptez.o -r - sptez.o -rm -f sptez.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezmd.f -ar -ruv ../splib_v2/libsp_8.a sptezmd.o -r - sptezmd.o -rm -f sptezmd.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezm.f -ar -ruv ../splib_v2/libsp_8.a sptezm.o -r - sptezm.o -rm -f sptezm.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezmv.f -ar -ruv ../splib_v2/libsp_8.a sptezmv.o -r - sptezmv.o -rm -f sptezmv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezv.f -ar -ruv ../splib_v2/libsp_8.a sptezv.o -r - sptezv.o -rm -f sptezv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpmd.f -ar -ruv ../splib_v2/libsp_8.a sptgpmd.o -r - sptgpmd.o -rm -f sptgpmd.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpm.f -ar -ruv ../splib_v2/libsp_8.a sptgpm.o -r - sptgpm.o -rm -f sptgpm.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpmv.f -ar -ruv ../splib_v2/libsp_8.a sptgpmv.o -r - sptgpmv.o -rm -f sptgpmv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpsd.f -ar -ruv ../splib_v2/libsp_8.a sptgpsd.o -r - sptgpsd.o -rm -f sptgpsd.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgps.f -ar -ruv ../splib_v2/libsp_8.a sptgps.o -r - sptgps.o -rm -f sptgps.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpsv.f -ar -ruv ../splib_v2/libsp_8.a sptgpsv.o -r - sptgpsv.o -rm -f sptgpsv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgptd.f -ar -ruv ../splib_v2/libsp_8.a sptgptd.o -r - sptgptd.o -rm -f sptgptd.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpt.f -ar -ruv ../splib_v2/libsp_8.a sptgpt.o -r - sptgpt.o -rm -f sptgpt.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgptsd.f -ar -ruv ../splib_v2/libsp_8.a sptgptsd.o -r - sptgptsd.o -rm -f sptgptsd.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgptvd.f -ar -ruv ../splib_v2/libsp_8.a sptgptvd.o -r - sptgptvd.o -rm -f sptgptvd.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgptv.f -ar -ruv ../splib_v2/libsp_8.a sptgptv.o -r - sptgptv.o -rm -f sptgptv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrand.f -ar -ruv ../splib_v2/libsp_8.a sptrand.o -r - sptrand.o -rm -f sptrand.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptran.f -ar -ruv ../splib_v2/libsp_8.a sptran.o -r - sptran.o -rm -f sptran.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranf0.f -ar -ruv ../splib_v2/libsp_8.a sptranf0.o -r - sptranf0.o -rm -f sptranf0.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranf1.f -ar -ruv ../splib_v2/libsp_8.a sptranf1.o -r - sptranf1.o -rm -f sptranf1.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranf.f -ar -ruv ../splib_v2/libsp_8.a sptranf.o -r - sptranf.o -rm -f sptranf.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranfv.f -ar -ruv ../splib_v2/libsp_8.a sptranfv.o -r - sptranfv.o -rm -f sptranfv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranv.f -ar -ruv ../splib_v2/libsp_8.a sptranv.o -r - sptranv.o -rm -f sptranv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrund.f -ar -ruv ../splib_v2/libsp_8.a sptrund.o -r - sptrund.o -rm -f sptrund.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrun.f -ar -ruv ../splib_v2/libsp_8.a sptrun.o -r - sptrun.o -rm -f sptrun.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrung.f -ar -ruv ../splib_v2/libsp_8.a sptrung.o -r - sptrung.o -rm -f sptrung.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrungv.f -ar -ruv ../splib_v2/libsp_8.a sptrungv.o -r - sptrungv.o -rm -f sptrungv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunl.f -ar -ruv ../splib_v2/libsp_8.a sptrunl.o -r - sptrunl.o -rm -f sptrunl.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunm.f -ar -ruv ../splib_v2/libsp_8.a sptrunm.o -r - sptrunm.o -rm -f sptrunm.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunmv.f -ar -ruv ../splib_v2/libsp_8.a sptrunmv.o -r - sptrunmv.o -rm -f sptrunmv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptruns.f -ar -ruv ../splib_v2/libsp_8.a sptruns.o -r - sptruns.o -rm -f sptruns.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunsv.f -ar -ruv ../splib_v2/libsp_8.a sptrunsv.o -r - sptrunsv.o -rm -f sptrunsv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunv.f -ar -ruv ../splib_v2/libsp_8.a sptrunv.o -r - sptrunv.o -rm -f sptrunv.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spuv2dz.f -ar -ruv ../splib_v2/libsp_8.a spuv2dz.o -r - spuv2dz.o -rm -f spuv2dz.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spvar.f -ar -ruv ../splib_v2/libsp_8.a spvar.o -r - spvar.o -rm -f spvar.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spwget.f -ar -ruv ../splib_v2/libsp_8.a spwget.o -r - spwget.o -rm -f spwget.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX fftpack.F -ar -ruv ../splib_v2/libsp_8.a fftpack.o -r - fftpack.o -rm -f fftpack.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX lapack_gen.F -ar -ruv ../splib_v2/libsp_8.a lapack_gen.o -r - lapack_gen.o -rm -f lapack_gen.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX ncpus.F -ar -ruv ../splib_v2/libsp_8.a ncpus.o -r - ncpus.o -rm -f ncpus.o -ifort -c -O3 -auto -openmp -i8 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX splat.F -ar -ruv ../splib_v2/libsp_8.a splat.o -r - splat.o -rm -f splat.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spanaly.f -ar -ruv ../splib_v2/libsp_d.a spanaly.o -r - spanaly.o -rm -f spanaly.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spdz2uv.f -ar -ruv ../splib_v2/libsp_d.a spdz2uv.o -r - spdz2uv.o -rm -f spdz2uv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX speps.f -ar -ruv ../splib_v2/libsp_d.a speps.o -r - speps.o -rm -f speps.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spfft1.f -ar -ruv ../splib_v2/libsp_d.a spfft1.o -r - spfft1.o -rm -f spfft1.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spffte.f -ar -ruv ../splib_v2/libsp_d.a spffte.o -r - spffte.o -rm -f spffte.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spfft.f -ar -ruv ../splib_v2/libsp_d.a spfft.o -r - spfft.o -rm -f spfft.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spfftpt.f -ar -ruv ../splib_v2/libsp_d.a spfftpt.o -r - spfftpt.o -rm -f spfftpt.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spgradq.f -ar -ruv ../splib_v2/libsp_d.a spgradq.o -r - spgradq.o -rm -f spgradq.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spgradx.f -ar -ruv ../splib_v2/libsp_d.a spgradx.o -r - spgradx.o -rm -f spgradx.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spgrady.f -ar -ruv ../splib_v2/libsp_d.a spgrady.o -r - spgrady.o -rm -f spgrady.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX splaplac.f -ar -ruv ../splib_v2/libsp_d.a splaplac.o -r - splaplac.o -rm -f splaplac.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX splegend.f -ar -ruv ../splib_v2/libsp_d.a splegend.o -r - splegend.o -rm -f splegend.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sppad.f -ar -ruv ../splib_v2/libsp_d.a sppad.o -r - sppad.o -rm -f sppad.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spsynth.f -ar -ruv ../splib_v2/libsp_d.a spsynth.o -r - spsynth.o -rm -f spsynth.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezd.f -ar -ruv ../splib_v2/libsp_d.a sptezd.o -r - sptezd.o -rm -f sptezd.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptez.f -ar -ruv ../splib_v2/libsp_d.a sptez.o -r - sptez.o -rm -f sptez.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezmd.f -ar -ruv ../splib_v2/libsp_d.a sptezmd.o -r - sptezmd.o -rm -f sptezmd.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezm.f -ar -ruv ../splib_v2/libsp_d.a sptezm.o -r - sptezm.o -rm -f sptezm.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezmv.f -ar -ruv ../splib_v2/libsp_d.a sptezmv.o -r - sptezmv.o -rm -f sptezmv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptezv.f -ar -ruv ../splib_v2/libsp_d.a sptezv.o -r - sptezv.o -rm -f sptezv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpmd.f -ar -ruv ../splib_v2/libsp_d.a sptgpmd.o -r - sptgpmd.o -rm -f sptgpmd.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpm.f -ar -ruv ../splib_v2/libsp_d.a sptgpm.o -r - sptgpm.o -rm -f sptgpm.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpmv.f -ar -ruv ../splib_v2/libsp_d.a sptgpmv.o -r - sptgpmv.o -rm -f sptgpmv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpsd.f -ar -ruv ../splib_v2/libsp_d.a sptgpsd.o -r - sptgpsd.o -rm -f sptgpsd.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgps.f -ar -ruv ../splib_v2/libsp_d.a sptgps.o -r - sptgps.o -rm -f sptgps.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpsv.f -ar -ruv ../splib_v2/libsp_d.a sptgpsv.o -r - sptgpsv.o -rm -f sptgpsv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgptd.f -ar -ruv ../splib_v2/libsp_d.a sptgptd.o -r - sptgptd.o -rm -f sptgptd.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgpt.f -ar -ruv ../splib_v2/libsp_d.a sptgpt.o -r - sptgpt.o -rm -f sptgpt.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgptsd.f -ar -ruv ../splib_v2/libsp_d.a sptgptsd.o -r - sptgptsd.o -rm -f sptgptsd.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgptvd.f -ar -ruv ../splib_v2/libsp_d.a sptgptvd.o -r - sptgptvd.o -rm -f sptgptvd.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptgptv.f -ar -ruv ../splib_v2/libsp_d.a sptgptv.o -r - sptgptv.o -rm -f sptgptv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrand.f -ar -ruv ../splib_v2/libsp_d.a sptrand.o -r - sptrand.o -rm -f sptrand.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptran.f -ar -ruv ../splib_v2/libsp_d.a sptran.o -r - sptran.o -rm -f sptran.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranf0.f -ar -ruv ../splib_v2/libsp_d.a sptranf0.o -r - sptranf0.o -rm -f sptranf0.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranf1.f -ar -ruv ../splib_v2/libsp_d.a sptranf1.o -r - sptranf1.o -rm -f sptranf1.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranf.f -ar -ruv ../splib_v2/libsp_d.a sptranf.o -r - sptranf.o -rm -f sptranf.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranfv.f -ar -ruv ../splib_v2/libsp_d.a sptranfv.o -r - sptranfv.o -rm -f sptranfv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptranv.f -ar -ruv ../splib_v2/libsp_d.a sptranv.o -r - sptranv.o -rm -f sptranv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrund.f -ar -ruv ../splib_v2/libsp_d.a sptrund.o -r - sptrund.o -rm -f sptrund.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrun.f -ar -ruv ../splib_v2/libsp_d.a sptrun.o -r - sptrun.o -rm -f sptrun.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrung.f -ar -ruv ../splib_v2/libsp_d.a sptrung.o -r - sptrung.o -rm -f sptrung.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrungv.f -ar -ruv ../splib_v2/libsp_d.a sptrungv.o -r - sptrungv.o -rm -f sptrungv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunl.f -ar -ruv ../splib_v2/libsp_d.a sptrunl.o -r - sptrunl.o -rm -f sptrunl.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunm.f -ar -ruv ../splib_v2/libsp_d.a sptrunm.o -r - sptrunm.o -rm -f sptrunm.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunmv.f -ar -ruv ../splib_v2/libsp_d.a sptrunmv.o -r - sptrunmv.o -rm -f sptrunmv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptruns.f -ar -ruv ../splib_v2/libsp_d.a sptruns.o -r - sptruns.o -rm -f sptruns.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunsv.f -ar -ruv ../splib_v2/libsp_d.a sptrunsv.o -r - sptrunsv.o -rm -f sptrunsv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX sptrunv.f -ar -ruv ../splib_v2/libsp_d.a sptrunv.o -r - sptrunv.o -rm -f sptrunv.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spuv2dz.f -ar -ruv ../splib_v2/libsp_d.a spuv2dz.o -r - spuv2dz.o -rm -f spuv2dz.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spvar.f -ar -ruv ../splib_v2/libsp_d.a spvar.o -r - spvar.o -rm -f spvar.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX spwget.f -ar -ruv ../splib_v2/libsp_d.a spwget.o -r - spwget.o -rm -f spwget.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX fftpack.F -ar -ruv ../splib_v2/libsp_d.a fftpack.o -r - fftpack.o -rm -f fftpack.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX lapack_gen.F -ar -ruv ../splib_v2/libsp_d.a lapack_gen.o -r - lapack_gen.o -rm -f lapack_gen.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX ncpus.F -ar -ruv ../splib_v2/libsp_d.a ncpus.o -r - ncpus.o -rm -f ncpus.o -ifort -c -O3 -auto -openmp -i4 -r8 -convert big_endian -assume byterecl -fp-model strict -fpp -DLINUX splat.F -ar -ruv ../splib_v2/libsp_d.a splat.o -r - splat.o -rm -f splat.o diff --git a/external/sp/v2.0.2/src/fftpack.F b/external/sp/v2.0.2/src/fftpack.F deleted file mode 100644 index afc1790c9..000000000 --- a/external/sp/v2.0.2/src/fftpack.F +++ /dev/null @@ -1,1091 +0,0 @@ -#if LINUX - SUBROUTINE dcrft(init,x,ldx,y,ldy,n,m,isign,scale, - & table,n1,wrk,n2,z,nz) - - implicit none - integer init,ldx,ldy,n,m,isign,n1,n2,nz,i,j - real x(2*ldx,*),y(ldy,*),scale,table(44002),wrk,z - - IF (init.ne.0) THEN - CALL rffti(n,table) - ELSE -!OCL NOVREC - DO j=1,m - y(1,j)=x(1,j) - DO i=2,n - y(i,j)=x(i+1,j) - ENDDO - CALL rfftb(n,y(1,j),table) - DO i=1,n - y(i,j)=scale*y(i,j) - ENDDO - ENDDO - ENDIF - - RETURN - END - - SUBROUTINE scrft(init,x,ldx,y,ldy,n,m,isign,scale, - & table,n1,wrk,n2,z,nz) - - implicit none - integer init,ldx,ldy,n,m,isign,n1,n2,nz,i,j - real x(2*ldx,*),y(ldy,*),scale,table(44002),wrk,z - - IF (init.ne.0) THEN - CALL rffti(n,table) - ELSE -!OCL NOVREC - DO j=1,m - y(1,j)=x(1,j) - DO i=2,n - y(i,j)=x(i+1,j) - ENDDO - CALL rfftb(n,y(1,j),table) - DO i=1,n - y(i,j)=scale*y(i,j) - ENDDO - ENDDO - ENDIF - - RETURN - END -c -c*********************************************************************** -c - SUBROUTINE csfft(isign,n,scale,x,y,table,work,isys) - - implicit none - integer isign,n,isys,i - real scale,x(*),y(*),table(*),work(*) - - IF (isign.eq.0) THEN - CALL rffti(n,table) - ENDIF - IF (isign.eq.1) THEN - y(1)=x(1) - DO i=2,n - y(i)=x(i+1) - ENDDO - CALL rfftb(n,y,table) - DO i=1,n - y(i)=scale*y(i) - ENDDO - ENDIF - - RETURN - END -c -c*********************************************************************** -c - SUBROUTINE drcft(init,x,ldx,y,ldy,n,m,isign,scale, - & table,n1,wrk,n2,z,nz) - - implicit none - integer init,ldx,ldy,n,m,isign,n1,n2,nz,i,j - real x(ldx,*),y(2*ldy,*),scale,table(44002),wrk,z - - IF (init.ne.0) THEN - CALL rffti(n,table) - ELSE - DO j=1,m - DO i=1,n - y(i,j)=x(i,j) - ENDDO - CALL rfftf(n,y(1,j),table) - DO i=1,n - y(i,j)=scale*y(i,j) - ENDDO - DO i=n,2,-1 - y(i+1,j)=y(i,j) - ENDDO - y(2,j)=0. -C 01/17/2013 vvvvvvvvvvvvv E.Mirvis added ver 2.0.1 by S.Moorthi request. No +|- demo. - y(n+2,j) = 0. - ENDDO - ENDIF - - RETURN - END - - SUBROUTINE srcft(init,x,ldx,y,ldy,n,m,isign,scale, - & table,n1,wrk,n2,z,nz) - - implicit none - integer init,ldx,ldy,n,m,isign,n1,n2,nz,i,j - real x(ldx,*),y(2*ldy,*),scale,table(44002),wrk,z - - IF (init.ne.0) THEN - CALL rffti(n,table) - ELSE - DO j=1,m - DO i=1,n - y(i,j)=x(i,j) - ENDDO - CALL rfftf(n,y(1,j),table) - DO i=1,n - y(i,j)=scale*y(i,j) - ENDDO - DO i=n,2,-1 - y(i+1,j)=y(i,j) - ENDDO - y(2,j)=0. - y(n+2,j) = 0. -C 01/17/2013 ^^^^^^^^^^E.Mirvis added ver 2.0.1 by S.Moorthi request. No +|- demo. - ENDDO - ENDIF - - RETURN - END -c -c*********************************************************************** -c - SUBROUTINE scfft(isign,n,scale,x,y,table,work,isys) - - implicit none - integer isign,n,isys,i - real scale,x(*),y(*),table(*),work(*) - - IF (isign.eq.0) THEN - CALL rffti(n,table) - ENDIF - IF (isign.eq.-1) THEN - DO i=1,n - y(i)=x(i) - ENDDO - CALL rfftf(n,y,table) - DO i=1,n - y(i)=scale*y(i) - ENDDO - DO i=n,2,-1 - y(i+1)=y(i) - ENDDO - y(2)=0. - ENDIF - - RETURN - END -c -c ****************************************************************** -c ****************************************************************** -c ****** ****** -c ****** FFTPACK ****** -c ****** ****** -c ****************************************************************** -c ****************************************************************** -c - SUBROUTINE RFFTF (N,R,WSAVE) - DIMENSION R(1) ,WSAVE(1) - IF (N .EQ. 1) RETURN - CALL RFFTF1 (N,R,WSAVE,WSAVE(N+1),WSAVE(2*N+1)) - RETURN - END - SUBROUTINE RFFTB (N,R,WSAVE) - DIMENSION R(1) ,WSAVE(1) - IF (N .EQ. 1) RETURN - CALL RFFTB1 (N,R,WSAVE,WSAVE(N+1),WSAVE(2*N+1)) - RETURN - END - SUBROUTINE RFFTI (N,WSAVE) - DIMENSION WSAVE(1) - IF (N .EQ. 1) RETURN - CALL RFFTI1 (N,WSAVE(N+1),WSAVE(2*N+1)) - RETURN - END - SUBROUTINE RFFTB1 (N,C,CH,WA,IFAC) - DIMENSION CH(1) ,C(1) ,WA(1) ,IFAC(*) - NF = IFAC(2) - NA = 0 - L1 = 1 - IW = 1 - DO 116 K1=1,NF - IP = IFAC(K1+2) - L2 = IP*L1 - IDO = N/L2 - IDL1 = IDO*L1 - IF (IP .NE. 4) GO TO 103 - IX2 = IW+IDO - IX3 = IX2+IDO - IF (NA .NE. 0) GO TO 101 - CALL RADB4 (IDO,L1,C,CH,WA(IW),WA(IX2),WA(IX3)) - GO TO 102 - 101 CALL RADB4 (IDO,L1,CH,C,WA(IW),WA(IX2),WA(IX3)) - 102 NA = 1-NA - GO TO 115 - 103 IF (IP .NE. 2) GO TO 106 - IF (NA .NE. 0) GO TO 104 - CALL RADB2 (IDO,L1,C,CH,WA(IW)) - GO TO 105 - 104 CALL RADB2 (IDO,L1,CH,C,WA(IW)) - 105 NA = 1-NA - GO TO 115 - 106 IF (IP .NE. 3) GO TO 109 - IX2 = IW+IDO - IF (NA .NE. 0) GO TO 107 - CALL RADB3 (IDO,L1,C,CH,WA(IW),WA(IX2)) - GO TO 108 - 107 CALL RADB3 (IDO,L1,CH,C,WA(IW),WA(IX2)) - 108 NA = 1-NA - GO TO 115 - 109 IF (IP .NE. 5) GO TO 112 - IX2 = IW+IDO - IX3 = IX2+IDO - IX4 = IX3+IDO - IF (NA .NE. 0) GO TO 110 - CALL RADB5 (IDO,L1,C,CH,WA(IW),WA(IX2),WA(IX3),WA(IX4)) - GO TO 111 - 110 CALL RADB5 (IDO,L1,CH,C,WA(IW),WA(IX2),WA(IX3),WA(IX4)) - 111 NA = 1-NA - GO TO 115 - 112 IF (NA .NE. 0) GO TO 113 - CALL RADBG (IDO,IP,L1,IDL1,C,C,C,CH,CH,WA(IW)) - GO TO 114 - 113 CALL RADBG (IDO,IP,L1,IDL1,CH,CH,CH,C,C,WA(IW)) - 114 IF (IDO .EQ. 1) NA = 1-NA - 115 L1 = L2 - IW = IW+(IP-1)*IDO - 116 CONTINUE - IF (NA .EQ. 0) RETURN - DO 117 I=1,N - C(I) = CH(I) - 117 CONTINUE - RETURN - END - - - SUBROUTINE RFFTF1 (N,C,CH,WA,IFAC) - DIMENSION CH(1) ,C(1) ,WA(1) ,IFAC(*) - NF = IFAC(2) - NA = 1 - L2 = N - IW = N - DO 111 K1=1,NF - KH = NF-K1 - IP = IFAC(KH+3) - L1 = L2/IP - IDO = N/L2 - IDL1 = IDO*L1 - IW = IW-(IP-1)*IDO - NA = 1-NA - IF (IP .NE. 4) GO TO 102 - IX2 = IW+IDO - IX3 = IX2+IDO - IF (NA .NE. 0) GO TO 101 - CALL RADF4 (IDO,L1,C,CH,WA(IW),WA(IX2),WA(IX3)) - GO TO 110 - 101 CALL RADF4 (IDO,L1,CH,C,WA(IW),WA(IX2),WA(IX3)) - GO TO 110 - 102 IF (IP .NE. 2) GO TO 104 - IF (NA .NE. 0) GO TO 103 - CALL RADF2 (IDO,L1,C,CH,WA(IW)) - GO TO 110 - 103 CALL RADF2 (IDO,L1,CH,C,WA(IW)) - GO TO 110 - 104 IF (IP .NE. 3) GO TO 106 - IX2 = IW+IDO - IF (NA .NE. 0) GO TO 105 - CALL RADF3 (IDO,L1,C,CH,WA(IW),WA(IX2)) - GO TO 110 - 105 CALL RADF3 (IDO,L1,CH,C,WA(IW),WA(IX2)) - GO TO 110 - 106 IF (IP .NE. 5) GO TO 108 - IX2 = IW+IDO - IX3 = IX2+IDO - IX4 = IX3+IDO - IF (NA .NE. 0) GO TO 107 - CALL RADF5 (IDO,L1,C,CH,WA(IW),WA(IX2),WA(IX3),WA(IX4)) - GO TO 110 - 107 CALL RADF5 (IDO,L1,CH,C,WA(IW),WA(IX2),WA(IX3),WA(IX4)) - GO TO 110 - 108 IF (IDO .EQ. 1) NA = 1-NA - IF (NA .NE. 0) GO TO 109 - CALL RADFG (IDO,IP,L1,IDL1,C,C,C,CH,CH,WA(IW)) - NA = 1 - GO TO 110 - 109 CALL RADFG (IDO,IP,L1,IDL1,CH,CH,CH,C,C,WA(IW)) - NA = 0 - 110 L2 = L1 - 111 CONTINUE - IF (NA .EQ. 1) RETURN - DO 112 I=1,N - C(I) = CH(I) - 112 CONTINUE - RETURN - END - - - SUBROUTINE RFFTI1 (N,WA,IFAC) - DIMENSION WA(1) ,IFAC(*) ,NTRYH(4) - DATA NTRYH(1),NTRYH(2),NTRYH(3),NTRYH(4)/4,2,3,5/ - NL = N - NF = 0 - J = 0 - 101 J = J+1 - IF (J-4) 102,102,103 - 102 NTRY = NTRYH(J) - GO TO 104 - 103 NTRY = NTRY+2 - 104 NQ = NL/NTRY - NR = NL-NTRY*NQ - IF (NR) 101,105,101 - 105 NF = NF+1 - IFAC(NF+2) = NTRY - NL = NQ - IF (NTRY .NE. 2) GO TO 107 - IF (NF .EQ. 1) GO TO 107 - DO 106 I=2,NF - IB = NF-I+2 - IFAC(IB+2) = IFAC(IB+1) - 106 CONTINUE - IFAC(3) = 2 - 107 IF (NL .NE. 1) GO TO 104 - IFAC(1) = N - IFAC(2) = NF - TPI = 6.28318530717959 - ARGH = TPI/FLOAT(N) - IS = 0 - NFM1 = NF-1 - L1 = 1 - IF (NFM1 .EQ. 0) RETURN -!OCL NOVREC - DO 110 K1=1,NFM1 - IP = IFAC(K1+2) - LD = 0 - L2 = L1*IP - IDO = N/L2 - IPM = IP-1 - DO 109 J=1,IPM - LD = LD+L1 - I = IS - ARGLD = FLOAT(LD)*ARGH - FI = 0 -!OCL SCALAR - DO 108 II=3,IDO,2 - I = I+2 - FI = FI+1 - ARG = FI*ARGLD - WA(I-1) = COS(ARG) - WA(I) = SIN(ARG) - 108 CONTINUE - IS = IS+IDO - 109 CONTINUE - L1 = L2 - 110 CONTINUE - RETURN - END - - - SUBROUTINE RADB2 (IDO,L1,CC,CH,WA1) - DIMENSION CC(IDO,2,L1) ,CH(IDO,L1,2) , - 1 WA1(1) - DO 101 K=1,L1 - CH(1,K,1) = CC(1,1,K)+CC(IDO,2,K) - CH(1,K,2) = CC(1,1,K)-CC(IDO,2,K) - 101 CONTINUE - IF (IDO-2) 107,105,102 - 102 IDP2 = IDO+2 -!OCL NOVREC - DO 104 K=1,L1 - DO 103 I=3,IDO,2 - IC = IDP2-I - CH(I-1,K,1) = CC(I-1,1,K)+CC(IC-1,2,K) - TR2 = CC(I-1,1,K)-CC(IC-1,2,K) - CH(I,K,1) = CC(I,1,K)-CC(IC,2,K) - TI2 = CC(I,1,K)+CC(IC,2,K) - CH(I-1,K,2) = WA1(I-2)*TR2-WA1(I-1)*TI2 - CH(I,K,2) = WA1(I-2)*TI2+WA1(I-1)*TR2 - 103 CONTINUE - 104 CONTINUE - IF (MOD(IDO,2) .EQ. 1) RETURN - 105 DO 106 K=1,L1 - CH(IDO,K,1) = CC(IDO,1,K)+CC(IDO,1,K) - CH(IDO,K,2) = -(CC(1,2,K)+CC(1,2,K)) - 106 CONTINUE - 107 RETURN - END - - - SUBROUTINE RADB3 (IDO,L1,CC,CH,WA1,WA2) - DIMENSION CC(IDO,3,L1) ,CH(IDO,L1,3) , - 1 WA1(1) ,WA2(1) - DATA TAUR,TAUI /-.5,.866025403784439/ - DO 101 K=1,L1 - TR2 = CC(IDO,2,K)+CC(IDO,2,K) - CR2 = CC(1,1,K)+TAUR*TR2 - CH(1,K,1) = CC(1,1,K)+TR2 - CI3 = TAUI*(CC(1,3,K)+CC(1,3,K)) - CH(1,K,2) = CR2-CI3 - CH(1,K,3) = CR2+CI3 - 101 CONTINUE - IF (IDO .EQ. 1) RETURN - IDP2 = IDO+2 -!OCL NOVREC - DO 103 K=1,L1 - DO 102 I=3,IDO,2 - IC = IDP2-I - TR2 = CC(I-1,3,K)+CC(IC-1,2,K) - CR2 = CC(I-1,1,K)+TAUR*TR2 - CH(I-1,K,1) = CC(I-1,1,K)+TR2 - TI2 = CC(I,3,K)-CC(IC,2,K) - CI2 = CC(I,1,K)+TAUR*TI2 - CH(I,K,1) = CC(I,1,K)+TI2 - CR3 = TAUI*(CC(I-1,3,K)-CC(IC-1,2,K)) - CI3 = TAUI*(CC(I,3,K)+CC(IC,2,K)) - DR2 = CR2-CI3 - DR3 = CR2+CI3 - DI2 = CI2+CR3 - DI3 = CI2-CR3 - CH(I-1,K,2) = WA1(I-2)*DR2-WA1(I-1)*DI2 - CH(I,K,2) = WA1(I-2)*DI2+WA1(I-1)*DR2 - CH(I-1,K,3) = WA2(I-2)*DR3-WA2(I-1)*DI3 - CH(I,K,3) = WA2(I-2)*DI3+WA2(I-1)*DR3 - 102 CONTINUE - 103 CONTINUE - RETURN - END - - - SUBROUTINE RADB4 (IDO,L1,CC,CH,WA1,WA2,WA3) - DIMENSION CC(IDO,4,L1) ,CH(IDO,L1,4) , - 1 WA1(1) ,WA2(1) ,WA3(1) - DATA SQRT2 /1.414213562373095/ - DO 101 K=1,L1 - TR1 = CC(1,1,K)-CC(IDO,4,K) - TR2 = CC(1,1,K)+CC(IDO,4,K) - TR3 = CC(IDO,2,K)+CC(IDO,2,K) - TR4 = CC(1,3,K)+CC(1,3,K) - CH(1,K,1) = TR2+TR3 - CH(1,K,2) = TR1-TR4 - CH(1,K,3) = TR2-TR3 - CH(1,K,4) = TR1+TR4 - 101 CONTINUE - IF (IDO-2) 107,105,102 - 102 IDP2 = IDO+2 -!OCL NOVREC - DO 104 K=1,L1 - DO 103 I=3,IDO,2 - IC = IDP2-I - TI1 = CC(I,1,K)+CC(IC,4,K) - TI2 = CC(I,1,K)-CC(IC,4,K) - TI3 = CC(I,3,K)-CC(IC,2,K) - TR4 = CC(I,3,K)+CC(IC,2,K) - TR1 = CC(I-1,1,K)-CC(IC-1,4,K) - TR2 = CC(I-1,1,K)+CC(IC-1,4,K) - TI4 = CC(I-1,3,K)-CC(IC-1,2,K) - TR3 = CC(I-1,3,K)+CC(IC-1,2,K) - CH(I-1,K,1) = TR2+TR3 - CR3 = TR2-TR3 - CH(I,K,1) = TI2+TI3 - CI3 = TI2-TI3 - CR2 = TR1-TR4 - CR4 = TR1+TR4 - CI2 = TI1+TI4 - CI4 = TI1-TI4 - CH(I-1,K,2) = WA1(I-2)*CR2-WA1(I-1)*CI2 - CH(I,K,2) = WA1(I-2)*CI2+WA1(I-1)*CR2 - CH(I-1,K,3) = WA2(I-2)*CR3-WA2(I-1)*CI3 - CH(I,K,3) = WA2(I-2)*CI3+WA2(I-1)*CR3 - CH(I-1,K,4) = WA3(I-2)*CR4-WA3(I-1)*CI4 - CH(I,K,4) = WA3(I-2)*CI4+WA3(I-1)*CR4 - 103 CONTINUE - 104 CONTINUE - IF (MOD(IDO,2) .EQ. 1) RETURN - 105 CONTINUE - DO 106 K=1,L1 - TI1 = CC(1,2,K)+CC(1,4,K) - TI2 = CC(1,4,K)-CC(1,2,K) - TR1 = CC(IDO,1,K)-CC(IDO,3,K) - TR2 = CC(IDO,1,K)+CC(IDO,3,K) - CH(IDO,K,1) = TR2+TR2 - CH(IDO,K,2) = SQRT2*(TR1-TI1) - CH(IDO,K,3) = TI2+TI2 - CH(IDO,K,4) = -SQRT2*(TR1+TI1) - 106 CONTINUE - 107 RETURN - END - - - SUBROUTINE RADB5 (IDO,L1,CC,CH,WA1,WA2,WA3,WA4) - DIMENSION CC(IDO,5,L1) ,CH(IDO,L1,5) , - 1 WA1(1) ,WA2(1) ,WA3(1) ,WA4(1) - DATA TR11,TI11,TR12,TI12 /.309016994374947,.951056516295154, - 1-.809016994374947,.587785252292473/ - DO 101 K=1,L1 - TI5 = CC(1,3,K)+CC(1,3,K) - TI4 = CC(1,5,K)+CC(1,5,K) - TR2 = CC(IDO,2,K)+CC(IDO,2,K) - TR3 = CC(IDO,4,K)+CC(IDO,4,K) - CH(1,K,1) = CC(1,1,K)+TR2+TR3 - CR2 = CC(1,1,K)+TR11*TR2+TR12*TR3 - CR3 = CC(1,1,K)+TR12*TR2+TR11*TR3 - CI5 = TI11*TI5+TI12*TI4 - CI4 = TI12*TI5-TI11*TI4 - CH(1,K,2) = CR2-CI5 - CH(1,K,3) = CR3-CI4 - CH(1,K,4) = CR3+CI4 - CH(1,K,5) = CR2+CI5 - 101 CONTINUE - IF (IDO .EQ. 1) RETURN - IDP2 = IDO+2 - DO 103 K=1,L1 - DO 102 I=3,IDO,2 - IC = IDP2-I - TI5 = CC(I,3,K)+CC(IC,2,K) - TI2 = CC(I,3,K)-CC(IC,2,K) - TI4 = CC(I,5,K)+CC(IC,4,K) - TI3 = CC(I,5,K)-CC(IC,4,K) - TR5 = CC(I-1,3,K)-CC(IC-1,2,K) - TR2 = CC(I-1,3,K)+CC(IC-1,2,K) - TR4 = CC(I-1,5,K)-CC(IC-1,4,K) - TR3 = CC(I-1,5,K)+CC(IC-1,4,K) - CH(I-1,K,1) = CC(I-1,1,K)+TR2+TR3 - CH(I,K,1) = CC(I,1,K)+TI2+TI3 - CR2 = CC(I-1,1,K)+TR11*TR2+TR12*TR3 - CI2 = CC(I,1,K)+TR11*TI2+TR12*TI3 - CR3 = CC(I-1,1,K)+TR12*TR2+TR11*TR3 - CI3 = CC(I,1,K)+TR12*TI2+TR11*TI3 - CR5 = TI11*TR5+TI12*TR4 - CI5 = TI11*TI5+TI12*TI4 - CR4 = TI12*TR5-TI11*TR4 - CI4 = TI12*TI5-TI11*TI4 - DR3 = CR3-CI4 - DR4 = CR3+CI4 - DI3 = CI3+CR4 - DI4 = CI3-CR4 - DR5 = CR2+CI5 - DR2 = CR2-CI5 - DI5 = CI2-CR5 - DI2 = CI2+CR5 - CH(I-1,K,2) = WA1(I-2)*DR2-WA1(I-1)*DI2 - CH(I,K,2) = WA1(I-2)*DI2+WA1(I-1)*DR2 - CH(I-1,K,3) = WA2(I-2)*DR3-WA2(I-1)*DI3 - CH(I,K,3) = WA2(I-2)*DI3+WA2(I-1)*DR3 - CH(I-1,K,4) = WA3(I-2)*DR4-WA3(I-1)*DI4 - CH(I,K,4) = WA3(I-2)*DI4+WA3(I-1)*DR4 - CH(I-1,K,5) = WA4(I-2)*DR5-WA4(I-1)*DI5 - CH(I,K,5) = WA4(I-2)*DI5+WA4(I-1)*DR5 - 102 CONTINUE - 103 CONTINUE - RETURN - END - - - SUBROUTINE RADBG (IDO,IP,L1,IDL1,CC,C1,C2,CH,CH2,WA) - DIMENSION CH(IDO,L1,IP) ,CC(IDO,IP,L1) , - 1 C1(IDO,L1,IP) ,C2(IDL1,IP), - 2 CH2(IDL1,IP) ,WA(1) - DATA TPI/6.28318530717959/ - ARG = TPI/FLOAT(IP) - DCP = COS(ARG) - DSP = SIN(ARG) - IDP2 = IDO+2 - NBD = (IDO-1)/2 - IPP2 = IP+2 - IPPH = (IP+1)/2 - IF (IDO .LT. L1) GO TO 103 - DO 102 K=1,L1 - DO 101 I=1,IDO - CH(I,K,1) = CC(I,1,K) - 101 CONTINUE - 102 CONTINUE - GO TO 106 - 103 DO 105 I=1,IDO - DO 104 K=1,L1 - CH(I,K,1) = CC(I,1,K) - 104 CONTINUE - 105 CONTINUE -!OCL NOVREC - 106 DO 108 J=2,IPPH - JC = IPP2-J - J2 = J+J - DO 107 K=1,L1 - CH(1,K,J) = CC(IDO,J2-2,K)+CC(IDO,J2-2,K) - CH(1,K,JC) = CC(1,J2-1,K)+CC(1,J2-1,K) - 107 CONTINUE - 108 CONTINUE - IF (IDO .EQ. 1) GO TO 116 - IF (NBD .LT. L1) GO TO 112 -!OCL NOVREC - DO 111 J=2,IPPH - JC = IPP2-J - DO 110 K=1,L1 - DO 109 I=3,IDO,2 - IC = IDP2-I - CH(I-1,K,J) = CC(I-1,2*J-1,K)+CC(IC-1,2*J-2,K) - CH(I-1,K,JC) = CC(I-1,2*J-1,K)-CC(IC-1,2*J-2,K) - CH(I,K,J) = CC(I,2*J-1,K)-CC(IC,2*J-2,K) - CH(I,K,JC) = CC(I,2*J-1,K)+CC(IC,2*J-2,K) - 109 CONTINUE - 110 CONTINUE - 111 CONTINUE - GO TO 116 - 112 DO 115 J=2,IPPH - JC = IPP2-J - DO 114 I=3,IDO,2 - IC = IDP2-I - DO 113 K=1,L1 - CH(I-1,K,J) = CC(I-1,2*J-1,K)+CC(IC-1,2*J-2,K) - CH(I-1,K,JC) = CC(I-1,2*J-1,K)-CC(IC-1,2*J-2,K) - CH(I,K,J) = CC(I,2*J-1,K)-CC(IC,2*J-2,K) - CH(I,K,JC) = CC(I,2*J-1,K)+CC(IC,2*J-2,K) - 113 CONTINUE - 114 CONTINUE - 115 CONTINUE - 116 AR1 = 1. - AI1 = 0. -!OCL NOVREC - DO 120 L=2,IPPH - LC = IPP2-L - AR1H = DCP*AR1-DSP*AI1 - AI1 = DCP*AI1+DSP*AR1 - AR1 = AR1H - DO 117 IK=1,IDL1 - C2(IK,L) = CH2(IK,1)+AR1*CH2(IK,2) - C2(IK,LC) = AI1*CH2(IK,IP) - 117 CONTINUE - DC2 = AR1 - DS2 = AI1 - AR2 = AR1 - AI2 = AI1 -!OCL NOVREC - DO 119 J=3,IPPH - JC = IPP2-J - AR2H = DC2*AR2-DS2*AI2 - AI2 = DC2*AI2+DS2*AR2 - AR2 = AR2H - DO 118 IK=1,IDL1 - C2(IK,L) = C2(IK,L)+AR2*CH2(IK,J) - C2(IK,LC) = C2(IK,LC)+AI2*CH2(IK,JC) - 118 CONTINUE - 119 CONTINUE - 120 CONTINUE -!OCL NOVREC - DO 122 J=2,IPPH - DO 121 IK=1,IDL1 - CH2(IK,1) = CH2(IK,1)+CH2(IK,J) - 121 CONTINUE - 122 CONTINUE -!OCL NOVREC - DO 124 J=2,IPPH - JC = IPP2-J - DO 123 K=1,L1 - CH(1,K,J) = C1(1,K,J)-C1(1,K,JC) - CH(1,K,JC) = C1(1,K,J)+C1(1,K,JC) - 123 CONTINUE - 124 CONTINUE - IF (IDO .EQ. 1) GO TO 132 - IF (NBD .LT. L1) GO TO 128 -!OCL NOVREC - DO 127 J=2,IPPH - JC = IPP2-J - DO 126 K=1,L1 - DO 125 I=3,IDO,2 - CH(I-1,K,J) = C1(I-1,K,J)-C1(I,K,JC) - CH(I-1,K,JC) = C1(I-1,K,J)+C1(I,K,JC) - CH(I,K,J) = C1(I,K,J)+C1(I-1,K,JC) - CH(I,K,JC) = C1(I,K,J)-C1(I-1,K,JC) - 125 CONTINUE - 126 CONTINUE - 127 CONTINUE - GO TO 132 - 128 DO 131 J=2,IPPH - JC = IPP2-J - DO 130 I=3,IDO,2 - DO 129 K=1,L1 - CH(I-1,K,J) = C1(I-1,K,J)-C1(I,K,JC) - CH(I-1,K,JC) = C1(I-1,K,J)+C1(I,K,JC) - CH(I,K,J) = C1(I,K,J)+C1(I-1,K,JC) - CH(I,K,JC) = C1(I,K,J)-C1(I-1,K,JC) - 129 CONTINUE - 130 CONTINUE - 131 CONTINUE - 132 CONTINUE - IF (IDO .EQ. 1) RETURN - DO 133 IK=1,IDL1 - C2(IK,1) = CH2(IK,1) - 133 CONTINUE - DO 135 J=2,IP - DO 134 K=1,L1 - C1(1,K,J) = CH(1,K,J) - 134 CONTINUE - 135 CONTINUE - IF (NBD .GT. L1) GO TO 139 - IS = -IDO - DO 138 J=2,IP - IS = IS+IDO - IDIJ = IS - DO 137 I=3,IDO,2 - IDIJ = IDIJ+2 - DO 136 K=1,L1 - C1(I-1,K,J) = WA(IDIJ-1)*CH(I-1,K,J)-WA(IDIJ)*CH(I,K,J) - C1(I,K,J) = WA(IDIJ-1)*CH(I,K,J)+WA(IDIJ)*CH(I-1,K,J) - 136 CONTINUE - 137 CONTINUE - 138 CONTINUE - GO TO 143 - 139 IS = -IDO -!OCL NOVREC - DO 142 J=2,IP - IS = IS+IDO - DO 141 K=1,L1 - IDIJ = IS - DO 140 I=3,IDO,2 - IDIJ = IDIJ+2 - C1(I-1,K,J) = WA(IDIJ-1)*CH(I-1,K,J)-WA(IDIJ)*CH(I,K,J) - C1(I,K,J) = WA(IDIJ-1)*CH(I,K,J)+WA(IDIJ)*CH(I-1,K,J) - 140 CONTINUE - 141 CONTINUE - 142 CONTINUE - 143 RETURN - END - - - SUBROUTINE RADF2 (IDO,L1,CC,CH,WA1) - DIMENSION CH(IDO,2,L1) ,CC(IDO,L1,2) , - 1 WA1(1) - DO 101 K=1,L1 - CH(1,1,K) = CC(1,K,1)+CC(1,K,2) - CH(IDO,2,K) = CC(1,K,1)-CC(1,K,2) - 101 CONTINUE - IF (IDO-2) 107,105,102 - 102 IDP2 = IDO+2 - DO 104 K=1,L1 - DO 103 I=3,IDO,2 - IC = IDP2-I - TR2 = WA1(I-2)*CC(I-1,K,2)+WA1(I-1)*CC(I,K,2) - TI2 = WA1(I-2)*CC(I,K,2)-WA1(I-1)*CC(I-1,K,2) - CH(I,1,K) = CC(I,K,1)+TI2 - CH(IC,2,K) = TI2-CC(I,K,1) - CH(I-1,1,K) = CC(I-1,K,1)+TR2 - CH(IC-1,2,K) = CC(I-1,K,1)-TR2 - 103 CONTINUE - 104 CONTINUE - IF (MOD(IDO,2) .EQ. 1) RETURN - 105 DO 106 K=1,L1 - CH(1,2,K) = -CC(IDO,K,2) - CH(IDO,1,K) = CC(IDO,K,1) - 106 CONTINUE - 107 RETURN - END - - - SUBROUTINE RADF3 (IDO,L1,CC,CH,WA1,WA2) - DIMENSION CH(IDO,3,L1) ,CC(IDO,L1,3) , - 1 WA1(1) ,WA2(1) - DATA TAUR,TAUI /-.5,.866025403784439/ - DO 101 K=1,L1 - CR2 = CC(1,K,2)+CC(1,K,3) - CH(1,1,K) = CC(1,K,1)+CR2 - CH(1,3,K) = TAUI*(CC(1,K,3)-CC(1,K,2)) - CH(IDO,2,K) = CC(1,K,1)+TAUR*CR2 - 101 CONTINUE - IF (IDO .EQ. 1) RETURN - IDP2 = IDO+2 - DO 103 K=1,L1 - DO 102 I=3,IDO,2 - IC = IDP2-I - DR2 = WA1(I-2)*CC(I-1,K,2)+WA1(I-1)*CC(I,K,2) - DI2 = WA1(I-2)*CC(I,K,2)-WA1(I-1)*CC(I-1,K,2) - DR3 = WA2(I-2)*CC(I-1,K,3)+WA2(I-1)*CC(I,K,3) - DI3 = WA2(I-2)*CC(I,K,3)-WA2(I-1)*CC(I-1,K,3) - CR2 = DR2+DR3 - CI2 = DI2+DI3 - CH(I-1,1,K) = CC(I-1,K,1)+CR2 - CH(I,1,K) = CC(I,K,1)+CI2 - TR2 = CC(I-1,K,1)+TAUR*CR2 - TI2 = CC(I,K,1)+TAUR*CI2 - TR3 = TAUI*(DI2-DI3) - TI3 = TAUI*(DR3-DR2) - CH(I-1,3,K) = TR2+TR3 - CH(IC-1,2,K) = TR2-TR3 - CH(I,3,K) = TI2+TI3 - CH(IC,2,K) = TI3-TI2 - 102 CONTINUE - 103 CONTINUE - RETURN - END - SUBROUTINE RADF4 (IDO,L1,CC,CH,WA1,WA2,WA3) - DIMENSION CC(IDO,L1,4) ,CH(IDO,4,L1) , - 1 WA1(1) ,WA2(1) ,WA3(1) - DATA HSQT2 /.7071067811865475/ - DO 101 K=1,L1 - TR1 = CC(1,K,2)+CC(1,K,4) - TR2 = CC(1,K,1)+CC(1,K,3) - CH(1,1,K) = TR1+TR2 - CH(IDO,4,K) = TR2-TR1 - CH(IDO,2,K) = CC(1,K,1)-CC(1,K,3) - CH(1,3,K) = CC(1,K,4)-CC(1,K,2) - 101 CONTINUE - IF (IDO-2) 107,105,102 - 102 IDP2 = IDO+2 -!OCL NOVREC - DO 104 K=1,L1 - DO 103 I=3,IDO,2 - IC = IDP2-I - CR2 = WA1(I-2)*CC(I-1,K,2)+WA1(I-1)*CC(I,K,2) - CI2 = WA1(I-2)*CC(I,K,2)-WA1(I-1)*CC(I-1,K,2) - CR3 = WA2(I-2)*CC(I-1,K,3)+WA2(I-1)*CC(I,K,3) - CI3 = WA2(I-2)*CC(I,K,3)-WA2(I-1)*CC(I-1,K,3) - CR4 = WA3(I-2)*CC(I-1,K,4)+WA3(I-1)*CC(I,K,4) - CI4 = WA3(I-2)*CC(I,K,4)-WA3(I-1)*CC(I-1,K,4) - TR1 = CR2+CR4 - TR4 = CR4-CR2 - TI1 = CI2+CI4 - TI4 = CI2-CI4 - TI2 = CC(I,K,1)+CI3 - TI3 = CC(I,K,1)-CI3 - TR2 = CC(I-1,K,1)+CR3 - TR3 = CC(I-1,K,1)-CR3 - CH(I-1,1,K) = TR1+TR2 - CH(IC-1,4,K) = TR2-TR1 - CH(I,1,K) = TI1+TI2 - CH(IC,4,K) = TI1-TI2 - CH(I-1,3,K) = TI4+TR3 - CH(IC-1,2,K) = TR3-TI4 - CH(I,3,K) = TR4+TI3 - CH(IC,2,K) = TR4-TI3 - 103 CONTINUE - 104 CONTINUE - IF (MOD(IDO,2) .EQ. 1) RETURN - 105 CONTINUE - DO 106 K=1,L1 - TI1 = -HSQT2*(CC(IDO,K,2)+CC(IDO,K,4)) - TR1 = HSQT2*(CC(IDO,K,2)-CC(IDO,K,4)) - CH(IDO,1,K) = TR1+CC(IDO,K,1) - CH(IDO,3,K) = CC(IDO,K,1)-TR1 - CH(1,2,K) = TI1-CC(IDO,K,3) - CH(1,4,K) = TI1+CC(IDO,K,3) - 106 CONTINUE - 107 RETURN - END - - - SUBROUTINE RADF5 (IDO,L1,CC,CH,WA1,WA2,WA3,WA4) - DIMENSION CC(IDO,L1,5) ,CH(IDO,5,L1) , - 1 WA1(1) ,WA2(1) ,WA3(1) ,WA4(1) - DATA TR11,TI11,TR12,TI12 /.309016994374947,.951056516295154, - 1-.809016994374947,.587785252292473/ - DO 101 K=1,L1 - CR2 = CC(1,K,5)+CC(1,K,2) - CI5 = CC(1,K,5)-CC(1,K,2) - CR3 = CC(1,K,4)+CC(1,K,3) - CI4 = CC(1,K,4)-CC(1,K,3) - CH(1,1,K) = CC(1,K,1)+CR2+CR3 - CH(IDO,2,K) = CC(1,K,1)+TR11*CR2+TR12*CR3 - CH(1,3,K) = TI11*CI5+TI12*CI4 - CH(IDO,4,K) = CC(1,K,1)+TR12*CR2+TR11*CR3 - CH(1,5,K) = TI12*CI5-TI11*CI4 - 101 CONTINUE - IF (IDO .EQ. 1) RETURN - IDP2 = IDO+2 - DO 103 K=1,L1 - DO 102 I=3,IDO,2 - IC = IDP2-I - DR2 = WA1(I-2)*CC(I-1,K,2)+WA1(I-1)*CC(I,K,2) - DI2 = WA1(I-2)*CC(I,K,2)-WA1(I-1)*CC(I-1,K,2) - DR3 = WA2(I-2)*CC(I-1,K,3)+WA2(I-1)*CC(I,K,3) - DI3 = WA2(I-2)*CC(I,K,3)-WA2(I-1)*CC(I-1,K,3) - DR4 = WA3(I-2)*CC(I-1,K,4)+WA3(I-1)*CC(I,K,4) - DI4 = WA3(I-2)*CC(I,K,4)-WA3(I-1)*CC(I-1,K,4) - DR5 = WA4(I-2)*CC(I-1,K,5)+WA4(I-1)*CC(I,K,5) - DI5 = WA4(I-2)*CC(I,K,5)-WA4(I-1)*CC(I-1,K,5) - CR2 = DR2+DR5 - CI5 = DR5-DR2 - CR5 = DI2-DI5 - CI2 = DI2+DI5 - CR3 = DR3+DR4 - CI4 = DR4-DR3 - CR4 = DI3-DI4 - CI3 = DI3+DI4 - CH(I-1,1,K) = CC(I-1,K,1)+CR2+CR3 - CH(I,1,K) = CC(I,K,1)+CI2+CI3 - TR2 = CC(I-1,K,1)+TR11*CR2+TR12*CR3 - TI2 = CC(I,K,1)+TR11*CI2+TR12*CI3 - TR3 = CC(I-1,K,1)+TR12*CR2+TR11*CR3 - TI3 = CC(I,K,1)+TR12*CI2+TR11*CI3 - TR5 = TI11*CR5+TI12*CR4 - TI5 = TI11*CI5+TI12*CI4 - TR4 = TI12*CR5-TI11*CR4 - TI4 = TI12*CI5-TI11*CI4 - CH(I-1,3,K) = TR2+TR5 - CH(IC-1,2,K) = TR2-TR5 - CH(I,3,K) = TI2+TI5 - CH(IC,2,K) = TI5-TI2 - CH(I-1,5,K) = TR3+TR4 - CH(IC-1,4,K) = TR3-TR4 - CH(I,5,K) = TI3+TI4 - CH(IC,4,K) = TI4-TI3 - 102 CONTINUE - 103 CONTINUE - RETURN - END - - - SUBROUTINE RADFG (IDO,IP,L1,IDL1,CC,C1,C2,CH,CH2,WA) - DIMENSION CH(IDO,L1,IP) ,CC(IDO,IP,L1) , - 1 C1(IDO,L1,IP) ,C2(IDL1,IP), - 2 CH2(IDL1,IP) ,WA(1) - DATA TPI/6.28318530717959/ - ARG = TPI/FLOAT(IP) - DCP = COS(ARG) - DSP = SIN(ARG) - IPPH = (IP+1)/2 - IPP2 = IP+2 - IDP2 = IDO+2 - NBD = (IDO-1)/2 - IF (IDO .EQ. 1) GO TO 119 - DO 101 IK=1,IDL1 - CH2(IK,1) = C2(IK,1) - 101 CONTINUE - DO 103 J=2,IP - DO 102 K=1,L1 - CH(1,K,J) = C1(1,K,J) - 102 CONTINUE - 103 CONTINUE - IF (NBD .GT. L1) GO TO 107 - IS = -IDO - DO 106 J=2,IP - IS = IS+IDO - IDIJ = IS - DO 105 I=3,IDO,2 - IDIJ = IDIJ+2 - DO 104 K=1,L1 - CH(I-1,K,J) = WA(IDIJ-1)*C1(I-1,K,J)+WA(IDIJ)*C1(I,K,J) - CH(I,K,J) = WA(IDIJ-1)*C1(I,K,J)-WA(IDIJ)*C1(I-1,K,J) - 104 CONTINUE - 105 CONTINUE - 106 CONTINUE - GO TO 111 - 107 IS = -IDO - DO 110 J=2,IP - IS = IS+IDO - DO 109 K=1,L1 - IDIJ = IS - DO 108 I=3,IDO,2 - IDIJ = IDIJ+2 - CH(I-1,K,J) = WA(IDIJ-1)*C1(I-1,K,J)+WA(IDIJ)*C1(I,K,J) - CH(I,K,J) = WA(IDIJ-1)*C1(I,K,J)-WA(IDIJ)*C1(I-1,K,J) - 108 CONTINUE - 109 CONTINUE - 110 CONTINUE - 111 IF (NBD .LT. L1) GO TO 115 - DO 114 J=2,IPPH - JC = IPP2-J - DO 113 K=1,L1 - DO 112 I=3,IDO,2 - C1(I-1,K,J) = CH(I-1,K,J)+CH(I-1,K,JC) - C1(I-1,K,JC) = CH(I,K,J)-CH(I,K,JC) - C1(I,K,J) = CH(I,K,J)+CH(I,K,JC) - C1(I,K,JC) = CH(I-1,K,JC)-CH(I-1,K,J) - 112 CONTINUE - 113 CONTINUE - 114 CONTINUE - GO TO 121 - 115 DO 118 J=2,IPPH - JC = IPP2-J - DO 117 I=3,IDO,2 - DO 116 K=1,L1 - C1(I-1,K,J) = CH(I-1,K,J)+CH(I-1,K,JC) - C1(I-1,K,JC) = CH(I,K,J)-CH(I,K,JC) - C1(I,K,J) = CH(I,K,J)+CH(I,K,JC) - C1(I,K,JC) = CH(I-1,K,JC)-CH(I-1,K,J) - 116 CONTINUE - 117 CONTINUE - 118 CONTINUE - GO TO 121 - 119 DO 120 IK=1,IDL1 - C2(IK,1) = CH2(IK,1) - 120 CONTINUE - 121 DO 123 J=2,IPPH - JC = IPP2-J - DO 122 K=1,L1 - C1(1,K,J) = CH(1,K,J)+CH(1,K,JC) - C1(1,K,JC) = CH(1,K,JC)-CH(1,K,J) - 122 CONTINUE - 123 CONTINUE -C - AR1 = 1. - AI1 = 0. - DO 127 L=2,IPPH - LC = IPP2-L - AR1H = DCP*AR1-DSP*AI1 - AI1 = DCP*AI1+DSP*AR1 - AR1 = AR1H - DO 124 IK=1,IDL1 - CH2(IK,L) = C2(IK,1)+AR1*C2(IK,2) - CH2(IK,LC) = AI1*C2(IK,IP) - 124 CONTINUE - DC2 = AR1 - DS2 = AI1 - AR2 = AR1 - AI2 = AI1 - DO 126 J=3,IPPH - JC = IPP2-J - AR2H = DC2*AR2-DS2*AI2 - AI2 = DC2*AI2+DS2*AR2 - AR2 = AR2H - DO 125 IK=1,IDL1 - CH2(IK,L) = CH2(IK,L)+AR2*C2(IK,J) - CH2(IK,LC) = CH2(IK,LC)+AI2*C2(IK,JC) - 125 CONTINUE - 126 CONTINUE - 127 CONTINUE - DO 129 J=2,IPPH - DO 128 IK=1,IDL1 - CH2(IK,1) = CH2(IK,1)+C2(IK,J) - 128 CONTINUE - 129 CONTINUE -C - IF (IDO .LT. L1) GO TO 132 - DO 131 K=1,L1 - DO 130 I=1,IDO - CC(I,1,K) = CH(I,K,1) - 130 CONTINUE - 131 CONTINUE - GO TO 135 - 132 DO 134 I=1,IDO - DO 133 K=1,L1 - CC(I,1,K) = CH(I,K,1) - 133 CONTINUE - 134 CONTINUE - 135 DO 137 J=2,IPPH - JC = IPP2-J - J2 = J+J - DO 136 K=1,L1 - CC(IDO,J2-2,K) = CH(1,K,J) - CC(1,J2-1,K) = CH(1,K,JC) - 136 CONTINUE - 137 CONTINUE - IF (IDO .EQ. 1) RETURN - IF (NBD .LT. L1) GO TO 141 - DO 140 J=2,IPPH - JC = IPP2-J - J2 = J+J - DO 139 K=1,L1 - DO 138 I=3,IDO,2 - IC = IDP2-I - CC(I-1,J2-1,K) = CH(I-1,K,J)+CH(I-1,K,JC) - CC(IC-1,J2-2,K) = CH(I-1,K,J)-CH(I-1,K,JC) - CC(I,J2-1,K) = CH(I,K,J)+CH(I,K,JC) - CC(IC,J2-2,K) = CH(I,K,JC)-CH(I,K,J) - 138 CONTINUE - 139 CONTINUE - 140 CONTINUE - RETURN - 141 DO 144 J=2,IPPH - JC = IPP2-J - J2 = J+J - DO 143 I=3,IDO,2 - IC = IDP2-I - DO 142 K=1,L1 - CC(I-1,J2-1,K) = CH(I-1,K,J)+CH(I-1,K,JC) - CC(IC-1,J2-2,K) = CH(I-1,K,J)-CH(I-1,K,JC) - CC(I,J2-1,K) = CH(I,K,J)+CH(I,K,JC) - CC(IC,J2-2,K) = CH(I,K,JC)-CH(I,K,J) - 142 CONTINUE - 143 CONTINUE - 144 CONTINUE - RETURN - END - -#endif diff --git a/external/sp/v2.0.2/src/lapack_gen.F b/external/sp/v2.0.2/src/lapack_gen.F deleted file mode 100644 index 3f550f9bb..000000000 --- a/external/sp/v2.0.2/src/lapack_gen.F +++ /dev/null @@ -1,105 +0,0 @@ -#if LINUX -!---------------------------------------------------------------------- -! From Numerical Recipes -! added two Numerical Recipes routines for matrix inversion -! LUBKSB - solves a system of linear equations, follows call to LUDCMP -! LUDCMP - replaces an NxN matrix a with the LU decomposition -! -! 2012-11-05 E.Mirvis separated this generic LU from the splat.F -!---------------------------------------------------------------------- - SUBROUTINE LUBKSB(A,N,NP,INDX,B) - REAL A(NP,NP),B(N) - INTEGER INDX(N) - II=0 - DO 12 I=1,N - LL=INDX(I) - SUM=B(LL) - B(LL)=B(I) - IF (II.NE.0)THEN - DO 11 J=II,I-1 - SUM=SUM-A(I,J)*B(J) - 11 CONTINUE - ELSE IF (SUM.NE.0.) THEN - II=I - ENDIF - B(I)=SUM - 12 CONTINUE - DO 14 I=N,1,-1 - SUM=B(I) - IF(I.LT.N)THEN - DO 13 J=I+1,N - SUM=SUM-A(I,J)*B(J) - 13 CONTINUE - ENDIF - B(I)=SUM/A(I,I) - 14 CONTINUE - RETURN - END - - SUBROUTINE LUDCMP(A,N,NP,INDX) -C PARAMETER (NMAX=400,TINY=1.0E-20) - PARAMETER (TINY=1.0E-20) -C==EM==^^^ -C - REAL A(NP,NP),VV(N),D -C REAL A(NP,NP),VV(NMAX),D -C==EM==^^^ - INTEGER INDX(N) - D=1. - DO 12 I=1,N - AAMAX=0. - DO 11 J=1,N - IF (ABS(A(I,J)).GT.AAMAX) AAMAX=ABS(A(I,J)) - 11 CONTINUE - IF (AAMAX.EQ.0.) print *, 'SINGULAR MATRIX.' - VV(I)=1./AAMAX - 12 CONTINUE - DO 19 J=1,N - IF (J.GT.1) THEN - DO 14 I=1,J-1 - SUM=A(I,J) - IF (I.GT.1)THEN - DO 13 K=1,I-1 - SUM=SUM-A(I,K)*A(K,J) - 13 CONTINUE - A(I,J)=SUM - ENDIF - 14 CONTINUE - ENDIF - AAMAX=0. - DO 16 I=J,N - SUM=A(I,J) - IF (J.GT.1)THEN - DO 15 K=1,J-1 - SUM=SUM-A(I,K)*A(K,J) - 15 CONTINUE - A(I,J)=SUM - ENDIF - DUM=VV(I)*ABS(SUM) - IF (DUM.GE.AAMAX) THEN - IMAX=I - AAMAX=DUM - ENDIF - 16 CONTINUE - IF (J.NE.IMAX)THEN - DO 17 K=1,N - DUM=A(IMAX,K) - A(IMAX,K)=A(J,K) - A(J,K)=DUM - 17 CONTINUE - D=-D - VV(IMAX)=VV(J) - ENDIF - INDX(J)=IMAX - IF(J.NE.N)THEN - IF(A(J,J).EQ.0.)A(J,J)=TINY - DUM=1./A(J,J) - DO 18 I=J+1,N - A(I,J)=A(I,J)*DUM - 18 CONTINUE - ENDIF - 19 CONTINUE - IF(A(N,N).EQ.0.)A(N,N)=TINY - RETURN - END -#endif diff --git a/external/sp/v2.0.2/src/ncpus.F b/external/sp/v2.0.2/src/ncpus.F deleted file mode 100644 index 4ff8ee0de..000000000 --- a/external/sp/v2.0.2/src/ncpus.F +++ /dev/null @@ -1,46 +0,0 @@ -C----------------------------------------------------------------------- - FUNCTION NCPUS() -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: NCPUS SET NUMBER OF CPUS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-08-19 -C -C ABSTRACT: SET NUMBER OF CPUS -C DESIGNATING THE NUMBER OF PROCESSORS OVER WHICH TO PARALLELIZE. -C -C PROGRAM HISTORY LOG: -C 94-08-19 IREDELL -C 98-11-09 VUONG ADD DOC BLOCK AND REMOVE CRAY REFERENCES -C 1998-12-18 IREDELL IBM SMP VERSION -C 2010-11-16 SLOVACEK LINUX MUST HAVE DIFFERENT CALL -C 2012-11-01 MIRVIS Multi- threading on LINUX-IBM/TIDE -C -C USAGE: NC=NCPUS() -C OUTPUT ARGUMENTS: -C NCPUS INTEGER NUMBER OF CPUS -C -C SUBPROGRAMS CALLED: -C NUM_PARTHDS XLF INTRINSIC TO RETURN NUMBER OF THREADSRTHDS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN -C -C$$$ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - INTEGER NTHREADS, TID, OMP_GET_NUM_THREADS,OMP_GET_THREAD_NUM -C Obtain thread number -#ifdef LINUX -!$OMP PARALLEL PRIVATE(TID) - TID = OMP_GET_THREAD_NUM() -! PRINT *, '...............thread # ', TID - if (TID. eq. 0) then - NCPUS=OMP_GET_NUM_THREADS() -! PRINT *, 'totaly #------------------- of threads = ',NCPUS - endif -!$OMP END PARALLEL -#else - NCPUS=NUM_PARTHDS() -#endif - - RETURN - END diff --git a/external/sp/v2.0.2/src/spanaly.f b/external/sp/v2.0.2/src/spanaly.f deleted file mode 100644 index 6a58d111d..000000000 --- a/external/sp/v2.0.2/src/spanaly.f +++ /dev/null @@ -1,89 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPANALY(I,M,IM,IX,NC,NCTOP,KM,WGT,CLAT,PLN,PLNTOP,MP, - & F,SPC,SPCTOP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPANALY ANALYZE SPECTRAL FROM FOURIER -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: ANALYZES SPECTRAL COEFFICIENTS FROM FOURIER COEFFICIENTS -C FOR A LATITUDE PAIR (NORTHERN AND SOUTHERN HEMISPHERES). -C VECTOR COMPONENTS ARE MULTIPLIED BY COSINE OF LATITUDE. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C 94-08-01 MARK IREDELL MOVED ZONAL WAVENUMBER LOOP INSIDE -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPANALY(I,M,IM,IX,NC,NCTOP,KM,WGT,CLAT,PLN,PLNTOP,MP, -C & F,SPC,SPCTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C IM - INTEGER EVEN NUMBER OF FOURIER COEFFICIENTS -C IX - INTEGER DIMENSION OF FOURIER COEFFICIENTS (IX>=IM+2) -C NC - INTEGER DIMENSION OF SPECTRAL COEFFICIENTS -C (NC>=(M+1)*((I+1)*M+2)) -C NCTOP - INTEGER DIMENSION OF SPECTRAL COEFFICIENTS OVER TOP -C (NCTOP>=2*(M+1)) -C KM - INTEGER NUMBER OF FIELDS -C WGT - REAL GAUSSIAN WEIGHT -C CLAT - REAL COSINE OF LATITUDE -C PLN - REAL ((M+1)*((I+1)*M+2)/2) LEGENDRE POLYNOMIALS -C PLNTOP - REAL (M+1) LEGENDRE POLYNOMIAL OVER TOP -C MP - INTEGER (KM) IDENTIFIERS (0 FOR SCALAR, 1 FOR VECTOR) -C F - REAL (IX,2,KM) FOURIER COEFFICIENTS COMBINED -C SPC - REAL (NC,KM) SPECTRAL COEFFICIENTS -C SPCTOP - REAL (NCTOP,KM) SPECTRAL COEFFICIENTS OVER TOP -C -C OUTPUT ARGUMENT LIST: -C SPC - REAL (NC,KM) SPECTRAL COEFFICIENTS -C SPCTOP - REAL (NCTOP,KM) SPECTRAL COEFFICIENTS OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - INTEGER MP(KM) - REAL PLN((M+1)*((I+1)*M+2)/2),PLNTOP(M+1) - REAL F(IX,2,KM) - REAL SPC(NC,KM),SPCTOP(NCTOP,KM) - REAL FW(2,2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FOR EACH ZONAL WAVENUMBER, ANALYZE TERMS OVER TOTAL WAVENUMBER. -C ANALYZE EVEN AND ODD POLYNOMIALS SEPARATELY. - LX=MIN(M,IM/2) -!C$OMP PARALLEL DO PRIVATE(L,NT,KS,KP,FW) - DO K=1,KM - DO L=0,LX - NT=MOD(M+1+(I-1)*L,2)+1 - KS=L*(2*M+(I-1)*(L-1)) - KP=KS/2+1 - IF(MP(K).EQ.0) THEN - FW(1,1)=WGT*(F(2*L+1,1,K)+F(2*L+1,2,K)) - FW(2,1)=WGT*(F(2*L+2,1,K)+F(2*L+2,2,K)) - FW(1,2)=WGT*(F(2*L+1,1,K)-F(2*L+1,2,K)) - FW(2,2)=WGT*(F(2*L+2,1,K)-F(2*L+2,2,K)) - ELSE - FW(1,1)=WGT*CLAT*(F(2*L+1,1,K)+F(2*L+1,2,K)) - FW(2,1)=WGT*CLAT*(F(2*L+2,1,K)+F(2*L+2,2,K)) - FW(1,2)=WGT*CLAT*(F(2*L+1,1,K)-F(2*L+1,2,K)) - FW(2,2)=WGT*CLAT*(F(2*L+2,1,K)-F(2*L+2,2,K)) - SPCTOP(2*L+1,K)=SPCTOP(2*L+1,K)+PLNTOP(L+1)*FW(1,NT) - SPCTOP(2*L+2,K)=SPCTOP(2*L+2,K)+PLNTOP(L+1)*FW(2,NT) - ENDIF - DO N=L,I*L+M,2 - SPC(KS+2*N+1,K)=SPC(KS+2*N+1,K)+PLN(KP+N)*FW(1,1) - SPC(KS+2*N+2,K)=SPC(KS+2*N+2,K)+PLN(KP+N)*FW(2,1) - ENDDO - DO N=L+1,I*L+M,2 - SPC(KS+2*N+1,K)=SPC(KS+2*N+1,K)+PLN(KP+N)*FW(1,2) - SPC(KS+2*N+2,K)=SPC(KS+2*N+2,K)+PLN(KP+N)*FW(2,2) - ENDDO - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/spdz2uv.f b/external/sp/v2.0.2/src/spdz2uv.f deleted file mode 100644 index 2ec5796af..000000000 --- a/external/sp/v2.0.2/src/spdz2uv.f +++ /dev/null @@ -1,85 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPDZ2UV(I,M,ENN1,ELONN1,EON,EONTOP,D,Z,U,V,UTOP,VTOP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE WIND COMPONENTS FROM DIVERGENCE AND VORTICITY -C IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) AND A IS EARTH RADIUS, -C THEN THE ZONAL WIND COMPONENT U IS COMPUTED AS -C U(L,N)=-I*L/(N*(N+1))*A*D(L,N) -C +EPS(L,N+1)/(N+1)*A*Z(L,N+1)-EPS(L,N)/N*A*Z(L,N-1) -C AND THE MERIDIONAL WIND COMPONENT V IS COMPUTED AS -C V(L,N)=-I*L/(N*(N+1))*A*Z(L,N) -C -EPS(L,N+1)/(N+1)*A*D(L,N+1)+EPS(L,N)/N*A*D(L,N-1) -C WHERE D IS DIVERGENCE AND Z IS VORTICITY. -C U AND V ARE WEIGHTED BY THE COSINE OF LATITUDE. -C EXTRA TERMS ARE COMPUTED OVER TOP OF THE SPECTRAL DOMAIN. -C ADVANTAGE IS TAKEN OF THE FACT THAT EPS(L,L)=0 -C IN ORDER TO VECTORIZE OVER THE ENTIRE SPECTRAL DOMAIN. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPDZ2UV(I,M,ENN1,ELONN1,EON,EONTOP,D,Z,U,V,UTOP,VTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C ELONN1 - REAL ((M+1)*((I+1)*M+2)/2) L/(N*(N+1))*A -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C D - REAL ((M+1)*((I+1)*M+2)) DIVERGENCE -C Z - REAL ((M+1)*((I+1)*M+2)) VORTICITY -C -C OUTPUT ARGUMENT LIST: -C U - REAL ((M+1)*((I+1)*M+2)) ZONAL WIND (TIMES COSLAT) -C V - REAL ((M+1)*((I+1)*M+2)) MERID WIND (TIMES COSLAT) -C UTOP - REAL (2*(M+1)) ZONAL WIND (TIMES COSLAT) OVER TOP -C VTOP - REAL (2*(M+1)) MERID WIND (TIMES COSLAT) OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - REAL ENN1((M+1)*((I+1)*M+2)/2),ELONN1((M+1)*((I+1)*M+2)/2) - REAL EON((M+1)*((I+1)*M+2)/2),EONTOP(M+1) - REAL D((M+1)*((I+1)*M+2)),Z((M+1)*((I+1)*M+2)) - REAL U((M+1)*((I+1)*M+2)),V((M+1)*((I+1)*M+2)) - REAL UTOP(2*(M+1)),VTOP(2*(M+1)) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE WINDS IN THE SPECTRAL DOMAIN - K=1 - U(2*K-1)=EON(K+1)*Z(2*K+1) - U(2*K)=EON(K+1)*Z(2*K+2) - V(2*K-1)=-EON(K+1)*D(2*K+1) - V(2*K)=-EON(K+1)*D(2*K+2) - DO K=2,(M+1)*((I+1)*M+2)/2-1 - U(2*K-1)=ELONN1(K)*D(2*K)+EON(K+1)*Z(2*K+1)-EON(K)*Z(2*K-3) - U(2*K)=-ELONN1(K)*D(2*K-1)+EON(K+1)*Z(2*K+2)-EON(K)*Z(2*K-2) - V(2*K-1)=ELONN1(K)*Z(2*K)-EON(K+1)*D(2*K+1)+EON(K)*D(2*K-3) - V(2*K)=-ELONN1(K)*Z(2*K-1)-EON(K+1)*D(2*K+2)+EON(K)*D(2*K-2) - ENDDO - K=(M+1)*((I+1)*M+2)/2 - U(2*K-1)=ELONN1(K)*D(2*K)-EON(K)*Z(2*K-3) - U(2*K)=-ELONN1(K)*D(2*K-1)-EON(K)*Z(2*K-2) - V(2*K-1)=ELONN1(K)*Z(2*K)+EON(K)*D(2*K-3) - V(2*K)=-ELONN1(K)*Z(2*K-1)+EON(K)*D(2*K-2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE WINDS OVER TOP OF THE SPECTRAL DOMAIN - DO L=0,M - K=L*(2*M+(I-1)*(L-1))/2+I*L+M+1 - UTOP(2*L+1)=-EONTOP(L+1)*Z(2*K-1) - UTOP(2*L+2)=-EONTOP(L+1)*Z(2*K) - VTOP(2*L+1)=EONTOP(L+1)*D(2*K-1) - VTOP(2*L+2)=EONTOP(L+1)*D(2*K) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/speps.f b/external/sp/v2.0.2/src/speps.f deleted file mode 100644 index bb7ad7217..000000000 --- a/external/sp/v2.0.2/src/speps.f +++ /dev/null @@ -1,67 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPEPS(I,M,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPEPS COMPUTE UTILITY SPECTRAL FIELDS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES CONSTANT FIELDS INDEXED IN THE SPECTRAL DOMAIN -C IN "IBM ORDER" (ZONAL WAVENUMBER IS THE SLOWER INDEX). -C IF L IS THE ZONAL WAVENUMBER AND N IS THE TOTAL WAVENUMBER -C AND A IS THE EARTH RADIUS, THEN THE FIELDS RETURNED ARE: -C (1) NORMALIZING FACTOR EPSILON=SQRT((N**2-L**2)/(4*N**2-1)) -C (2) LAPLACIAN FACTOR N*(N+1)/A**2 -C (3) ZONAL DERIVATIVE/LAPLACIAN FACTOR L/(N*(N+1))*A -C (4) MERIDIONAL DERIVATIVE/LAPLACIAN FACTOR EPSILON/N*A -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPEPS(I,M,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C -C OUTPUT ARGUMENT LIST: -C EPS - REAL ((M+1)*((I+1)*M+2)/2) SQRT((N**2-L**2)/(4*N**2-1)) -C EPSTOP - REAL (M+1) SQRT((N**2-L**2)/(4*N**2-1)) OVER TOP -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C ELONN1 - REAL ((M+1)*((I+1)*M+2)/2) L/(N*(N+1))*A -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - REAL EPS((M+1)*((I+1)*M+2)/2),EPSTOP(M+1) - REAL ENN1((M+1)*((I+1)*M+2)/2),ELONN1((M+1)*((I+1)*M+2)/2) - REAL EON((M+1)*((I+1)*M+2)/2),EONTOP(M+1) - PARAMETER(RERTH=6.3712E6,RA2=1./RERTH**2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - DO L=0,M - K=L*(2*M+(I-1)*(L-1))/2+L+1 - EPS(K)=0. - ENN1(K)=RA2*L*(L+1) - ELONN1(K)=RERTH/(L+1) - EON(K)=0. - ENDDO - DO L=0,M - DO N=L+1,I*L+M - K=L*(2*M+(I-1)*(L-1))/2+N+1 - EPS(K)=SQRT(FLOAT(N**2-L**2)/FLOAT(4*N**2-1)) - ENN1(K)=RA2*N*(N+1) - ELONN1(K)=RERTH*L/(N*(N+1)) - EON(K)=RERTH/N*EPS(K) - ENDDO - ENDDO - DO L=0,M - N=I*L+M+1 - EPSTOP(L+1)=SQRT(FLOAT(N**2-L**2)/FLOAT(4*N**2-1)) - EONTOP(L+1)=RERTH/N*EPSTOP(L+1) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/spfft.f b/external/sp/v2.0.2/src/spfft.f deleted file mode 100644 index d429aac82..000000000 --- a/external/sp/v2.0.2/src/spfft.f +++ /dev/null @@ -1,93 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPFFT(IMAX,INCW,INCG,KMAX,W,G,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPFFT PERFORM MULTIPLE FAST FOURIER TRANSFORMS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-20 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS MULTIPLE FAST FOURIER TRANSFORMS -C BETWEEN COMPLEX AMPLITUDES IN FOURIER SPACE AND REAL VALUES -C IN CYCLIC PHYSICAL SPACE. -C SUBPROGRAM SPFFT MUST BE INVOKED FIRST WITH IDIR=0 -C TO INITIALIZE TRIGONEMETRIC DATA. USE SUBPROGRAM SPFFT1 -C TO PERFORM AN FFT WITHOUT PREVIOUS INITIALIZATION. -C THIS VERSION INVOKES THE IBM ESSL FFT. -C -C PROGRAM HISTORY LOG: -C 1998-12-18 IREDELL -C -C USAGE: CALL SPFFT(IMAX,INCW,INCG,KMAX,W,G,IDIR) -C -C INPUT ARGUMENT LIST: -C IMAX - INTEGER NUMBER OF VALUES IN THE CYCLIC PHYSICAL SPACE -C (SEE LIMITATIONS ON IMAX IN REMARKS BELOW.) -C INCW - INTEGER FIRST DIMENSION OF THE COMPLEX AMPLITUDE ARRAY -C (INCW >= IMAX/2+1) -C INCG - INTEGER FIRST DIMENSION OF THE REAL VALUE ARRAY -C (INCG >= IMAX) -C KMAX - INTEGER NUMBER OF TRANSFORMS TO PERFORM -C W - COMPLEX(INCW,KMAX) COMPLEX AMPLITUDES IF IDIR>0 -C G - REAL(INCG,KMAX) REAL VALUES IF IDIR<0 -C IDIR - INTEGER DIRECTION FLAG -C IDIR=0 TO INITIALIZE INTERNAL TRIGONOMETRIC DATA -C IDIR>0 TO TRANSFORM FROM FOURIER TO PHYSICAL SPACE -C IDIR<0 TO TRANSFORM FROM PHYSICAL TO FOURIER SPACE -C -C OUTPUT ARGUMENT LIST: -C W - COMPLEX(INCW,KMAX) COMPLEX AMPLITUDES IF IDIR<0 -C G - REAL(INCG,KMAX) REAL VALUES IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SCRFT IBM ESSL COMPLEX TO REAL FOURIER TRANSFORM -C SRCFT IBM ESSL REAL TO COMPLEX FOURIER TRANSFORM -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C REMARKS: -C THE RESTRICTIONS ON IMAX ARE THAT IT MUST BE A MULTIPLE -C OF 1 TO 25 FACTORS OF TWO, UP TO 2 FACTORS OF THREE, -C AND UP TO 1 FACTOR OF FIVE, SEVEN AND ELEVEN. -C -C IF IDIR=0, THEN W AND G NEED NOT CONTAIN ANY VALID DATA. -C THE OTHER PARAMETERS MUST BE SUPPLIED AND CANNOT CHANGE -C IN SUCCEEDING CALLS UNTIL THE NEXT TIME IT IS CALLED WITH IDIR=0. -C -C THIS SUBPROGRAM IS NOT THREAD-SAFE WHEN IDIR=0. ON THE OTHER HAND, -C WHEN IDIR IS NOT ZERO, IT CAN BE CALLED FROM A THREADED REGION. -C -C$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: IMAX,INCW,INCG,KMAX,IDIR - COMPLEX,INTENT(INOUT):: W(INCW,KMAX) - REAL,INTENT(INOUT):: G(INCG,KMAX) - INTEGER,SAVE:: NAUX1=0 - REAL,SAVE,ALLOCATABLE:: AUX1CR(:),AUX1RC(:) - INTEGER:: NAUX2 - REAL:: AUX2(20000+INT(0.57*IMAX)) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - NAUX2=20000+INT(0.57*IMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C INITIALIZATION. -C ALLOCATE AND FILL AUXILIARY ARRAYS WITH TRIGONOMETRIC DATA - SELECT CASE(IDIR) - CASE(0) - IF(NAUX1.GT.0) DEALLOCATE(AUX1CR,AUX1RC) - NAUX1=25000+INT(0.82*IMAX) - ALLOCATE(AUX1CR(NAUX1),AUX1RC(NAUX1)) - CALL SCRFT(1,W,INCW,G,INCG,IMAX,KMAX,-1,1., - & AUX1CR,NAUX1,AUX2,NAUX2,0.,0) - CALL SRCFT(1,G,INCG,W,INCW,IMAX,KMAX,+1,1./IMAX, - & AUX1RC,NAUX1,AUX2,NAUX2,0.,0) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FOURIER TO PHYSICAL TRANSFORM. - CASE(1:) - CALL SCRFT(0,W,INCW,G,INCG,IMAX,KMAX,-1,1., - & AUX1CR,NAUX1,AUX2,NAUX2,0.,0) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PHYSICAL TO FOURIER TRANSFORM. - CASE(:-1) - CALL SRCFT(0,G,INCG,W,INCW,IMAX,KMAX,+1,1./IMAX, - & AUX1RC,NAUX1,AUX2,NAUX2,0.,0) - END SELECT - END SUBROUTINE diff --git a/external/sp/v2.0.2/src/spfft1.f b/external/sp/v2.0.2/src/spfft1.f deleted file mode 100644 index fe506a57e..000000000 --- a/external/sp/v2.0.2/src/spfft1.f +++ /dev/null @@ -1,79 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPFFT1(IMAX,INCW,INCG,KMAX,W,G,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPFFT1 PERFORM MULTIPLE FAST FOURIER TRANSFORMS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-20 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS MULTIPLE FAST FOURIER TRANSFORMS -C BETWEEN COMPLEX AMPLITUDES IN FOURIER SPACE AND REAL VALUES -C IN CYCLIC PHYSICAL SPACE. -C SUBPROGRAM SPFFT1 INITIALIZES TRIGONOMETRIC DATA EACH CALL. -C USE SUBPROGRAM SPFFT TO SAVE TIME AND INITIALIZE ONCE. -C THIS VERSION INVOKES THE IBM ESSL FFT. -C -C PROGRAM HISTORY LOG: -C 1998-12-18 IREDELL -C -C USAGE: CALL SPFFT1(IMAX,INCW,INCG,KMAX,W,G,IDIR) -C -C INPUT ARGUMENT LIST: -C IMAX - INTEGER NUMBER OF VALUES IN THE CYCLIC PHYSICAL SPACE -C (SEE LIMITATIONS ON IMAX IN REMARKS BELOW.) -C INCW - INTEGER FIRST DIMENSION OF THE COMPLEX AMPLITUDE ARRAY -C (INCW >= IMAX/2+1) -C INCG - INTEGER FIRST DIMENSION OF THE REAL VALUE ARRAY -C (INCG >= IMAX) -C KMAX - INTEGER NUMBER OF TRANSFORMS TO PERFORM -C W - COMPLEX(INCW,KMAX) COMPLEX AMPLITUDES IF IDIR>0 -C G - REAL(INCG,KMAX) REAL VALUES IF IDIR<0 -C IDIR - INTEGER DIRECTION FLAG -C IDIR>0 TO TRANSFORM FROM FOURIER TO PHYSICAL SPACE -C IDIR<0 TO TRANSFORM FROM PHYSICAL TO FOURIER SPACE -C -C OUTPUT ARGUMENT LIST: -C W - COMPLEX(INCW,KMAX) COMPLEX AMPLITUDES IF IDIR<0 -C G - REAL(INCG,KMAX) REAL VALUES IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SCRFT IBM ESSL COMPLEX TO REAL FOURIER TRANSFORM -C SRCFT IBM ESSL REAL TO COMPLEX FOURIER TRANSFORM -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C REMARKS: -C THE RESTRICTIONS ON IMAX ARE THAT IT MUST BE A MULTIPLE -C OF 1 TO 25 FACTORS OF TWO, UP TO 2 FACTORS OF THREE, -C AND UP TO 1 FACTOR OF FIVE, SEVEN AND ELEVEN. -C -C THIS SUBPROGRAM IS THREAD-SAFE. -C -C$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: IMAX,INCW,INCG,KMAX,IDIR - COMPLEX,INTENT(INOUT):: W(INCW,KMAX) - REAL,INTENT(INOUT):: G(INCG,KMAX) - REAL:: AUX1(25000+INT(0.82*IMAX)) - REAL:: AUX2(20000+INT(0.57*IMAX)) - INTEGER:: NAUX1,NAUX2 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - NAUX1=25000+INT(0.82*IMAX) - NAUX2=20000+INT(0.57*IMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FOURIER TO PHYSICAL TRANSFORM. - SELECT CASE(IDIR) - CASE(1:) - CALL SCRFT(1,W,INCW,G,INCG,IMAX,KMAX,-1,1., - & AUX1,NAUX1,AUX2,NAUX2,0.,0) - CALL SCRFT(0,W,INCW,G,INCG,IMAX,KMAX,-1,1., - & AUX1,NAUX1,AUX2,NAUX2,0.,0) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PHYSICAL TO FOURIER TRANSFORM. - CASE(:-1) - CALL SRCFT(1,G,INCG,W,INCW,IMAX,KMAX,+1,1./IMAX, - & AUX1,NAUX1,AUX2,NAUX2,0.,0) - CALL SRCFT(0,G,INCG,W,INCW,IMAX,KMAX,+1,1./IMAX, - & AUX1,NAUX1,AUX2,NAUX2,0.,0) - END SELECT - END SUBROUTINE diff --git a/external/sp/v2.0.2/src/spffte.f b/external/sp/v2.0.2/src/spffte.f deleted file mode 100644 index c52c81d76..000000000 --- a/external/sp/v2.0.2/src/spffte.f +++ /dev/null @@ -1,148 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPFFTE(IMAX,INCW,INCG,KMAX,W,G,IDIR,AFFT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPFFTE PERFORM MULTIPLE FAST FOURIER TRANSFORMS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-20 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS MULTIPLE FAST FOURIER TRANSFORMS -C BETWEEN COMPLEX AMPLITUDES IN FOURIER SPACE AND REAL VALUES -C IN CYCLIC PHYSICAL SPACE. -C SUBPROGRAM SPFFTE MUST BE INVOKED FIRST WITH IDIR=0 -C TO INITIALIZE TRIGONEMETRIC DATA. USE SUBPROGRAM SPFFT1 -C TO PERFORM AN FFT WITHOUT PREVIOUS INITIALIZATION. -C THIS VERSION INVOKES THE IBM ESSL FFT. -C -C PROGRAM HISTORY LOG: -C 1998-12-18 IREDELL -C 2012-11-12 MIRVIS -fixing hard-wired types problem on Intel/Linux - -C USAGE: CALL SPFFTE(IMAX,INCW,INCG,KMAX,W,G,IDIR,AFFT) -C -C INPUT ARGUMENT LIST: -C IMAX - INTEGER NUMBER OF VALUES IN THE CYCLIC PHYSICAL SPACE -C (SEE LIMITATIONS ON IMAX IN REMARKS BELOW.) -C INCW - INTEGER FIRST DIMENSION OF THE COMPLEX AMPLITUDE ARRAY -C (INCW >= IMAX/2+1) -C INCG - INTEGER FIRST DIMENSION OF THE REAL VALUE ARRAY -C (INCG >= IMAX) -C KMAX - INTEGER NUMBER OF TRANSFORMS TO PERFORM -C W - COMPLEX(INCW,KMAX) COMPLEX AMPLITUDES IF IDIR>0 -C G - REAL(INCG,KMAX) REAL VALUES IF IDIR<0 -C IDIR - INTEGER DIRECTION FLAG -C IDIR=0 TO INITIALIZE TRIGONOMETRIC DATA -C IDIR>0 TO TRANSFORM FROM FOURIER TO PHYSICAL SPACE -C IDIR<0 TO TRANSFORM FROM PHYSICAL TO FOURIER SPACE -C AFFT REAL(8) (50000+4*IMAX) AUXILIARY ARRAY IF IDIR<>0 -C -C OUTPUT ARGUMENT LIST: -C W - COMPLEX(INCW,KMAX) COMPLEX AMPLITUDES IF IDIR<0 -C G - REAL(INCG,KMAX) REAL VALUES IF IDIR>0 -C AFFT REAL(8) (50000+4*IMAX) AUXILIARY ARRAY IF IDIR=0 -C -C SUBPROGRAMS CALLED: -C SCRFT IBM ESSL COMPLEX TO REAL FOURIER TRANSFORM -C DCRFT IBM ESSL COMPLEX TO REAL FOURIER TRANSFORM -C SRCFT IBM ESSL REAL TO COMPLEX FOURIER TRANSFORM -C DRCFT IBM ESSL REAL TO COMPLEX FOURIER TRANSFORM -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C REMARKS: -C THE RESTRICTIONS ON IMAX ARE THAT IT MUST BE A MULTIPLE -C OF 1 TO 25 FACTORS OF TWO, UP TO 2 FACTORS OF THREE, -C AND UP TO 1 FACTOR OF FIVE, SEVEN AND ELEVEN. -C -C IF IDIR=0, THEN W AND G NEED NOT CONTAIN ANY VALID DATA. -C THE OTHER PARAMETERS MUST BE SUPPLIED AND CANNOT CHANGE -C IN SUCCEEDING CALLS UNTIL THE NEXT TIME IT IS CALLED WITH IDIR=0. -C -C THIS SUBPROGRAM IS THREAD-SAFE. -C -C$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: IMAX,INCW,INCG,KMAX,IDIR - REAL,INTENT(INOUT):: W(2*INCW,KMAX) - REAL,INTENT(INOUT):: G(INCG,KMAX) - REAL(8),INTENT(INOUT):: AFFT(50000+4*IMAX) - INTEGER:: INIT,INC2X,INC2Y,N,M,ISIGN,NAUX1,NAUX2,NAUX3 -C ==EM== ^(4) - REAL:: SCALE - REAL(8):: AUX2(20000+2*IMAX),AUX3 - INTEGER:: IACR,IARC -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - NAUX1=25000+2*IMAX - NAUX2=20000+2*IMAX - NAUX3=1 - IACR=1 - IARC=1+NAUX1 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C INITIALIZATION. -C FILL AUXILIARY ARRAYS WITH TRIGONOMETRIC DATA - SELECT CASE(IDIR) - CASE(0) - INIT=1 - INC2X=INCW - INC2Y=INCG - N=IMAX - M=KMAX - ISIGN=-1 - SCALE=1. - IF(DIGITS(1.).LT.DIGITS(1._8)) THEN - CALL SCRFT(INIT,W,INC2X,G,INC2Y,N,M,ISIGN,SCALE, - & AFFT(IACR),NAUX1,AUX2,NAUX2,AUX3,NAUX3) - ELSE - CALL DCRFT(INIT,W,INC2X,G,INC2Y,N,M,ISIGN,SCALE, - & AFFT(IACR),NAUX1,AUX2,NAUX2) - ENDIF - INIT=1 - INC2X=INCG - INC2Y=INCW - N=IMAX - M=KMAX - ISIGN=+1 - SCALE=1./IMAX - IF(DIGITS(1.).LT.DIGITS(1._8)) THEN - CALL SRCFT(INIT,G,INC2X,W,INC2Y,N,M,ISIGN,SCALE, - & AFFT(IARC),NAUX1,AUX2,NAUX2,AUX3,NAUX3) - ELSE - CALL DRCFT(INIT,G,INC2X,W,INC2Y,N,M,ISIGN,SCALE, - & AFFT(IARC),NAUX1,AUX2,NAUX2) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FOURIER TO PHYSICAL TRANSFORM. - CASE(1:) - INIT=0 - INC2X=INCW - INC2Y=INCG - N=IMAX - M=KMAX - ISIGN=-1 - SCALE=1. - IF(DIGITS(1.).LT.DIGITS(1._8)) THEN - CALL SCRFT(INIT,W,INC2X,G,INC2Y,N,M,ISIGN,SCALE, - & AFFT(IACR),NAUX1,AUX2,NAUX2,AUX3,NAUX3) - ELSE - CALL DCRFT(INIT,W,INC2X,G,INC2Y,N,M,ISIGN,SCALE, - & AFFT(IACR),NAUX1,AUX2,NAUX2) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PHYSICAL TO FOURIER TRANSFORM. - CASE(:-1) - INIT=0 - INC2X=INCG - INC2Y=INCW - N=IMAX - M=KMAX - ISIGN=+1 - SCALE=1./IMAX - IF(DIGITS(1.).LT.DIGITS(1._8)) THEN - CALL SRCFT(INIT,G,INC2X,W,INC2Y,N,M,ISIGN,SCALE, - & AFFT(IARC),NAUX1,AUX2,NAUX2,AUX3,NAUX3) - ELSE - CALL DRCFT(INIT,G,INC2X,W,INC2Y,N,M,ISIGN,SCALE, - & AFFT(IARC),NAUX1,AUX2,NAUX2) - ENDIF - END SELECT - END SUBROUTINE diff --git a/external/sp/v2.0.2/src/spfftpt.f b/external/sp/v2.0.2/src/spfftpt.f deleted file mode 100644 index 68f6bc57c..000000000 --- a/external/sp/v2.0.2/src/spfftpt.f +++ /dev/null @@ -1,64 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPFFTPT(M,N,INCW,INCG,KMAX,RLON,W,G) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPFFTPT COMPUTE FOURIER TRANSFORM TO GRIDPOINTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-20 -C -C ABSTRACT: THIS SUBPROGRAM COMPUTES A SLOW FOURIER TRANSFORM -C FROM FOURIER SPACE TO A SET OF GRIDPOINTS. -C -C PROGRAM HISTORY LOG: -C 1998-12-18 IREDELL -C -C USAGE: CALL SPFFTPT(M,N,INCW,INCG,KMAX,RLON,W,G) -C -C INPUT ARGUMENT LIST: -C M - INTEGER FOURIER WAVENUMBER TRUNCATION -C N - INTEGER NUMBER OF GRIDPOINTS -C INCW - INTEGER FIRST DIMENSION OF THE COMPLEX AMPLITUDE ARRAY -C (INCW >= M+1) -C INCG - INTEGER FIRST DIMENSION OF THE GRIDPOINT ARRAY -C (INCG >= N) -C KMAX - INTEGER NUMBER OF FOURIER FIELDS -C RLON - REAL(N) GRID LONGITUDES IN DEGREES -C W - COMPLEX(INCW,KMAX) FOURIER AMPLITUDES -C -C OUTPUT ARGUMENT LIST: -C G - REAL(INCG,KMAX) GRIDPOINT VALUES -C -C SUBPROGRAMS CALLED: -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C REMARKS: -C THIS SUBPROGRAM IS THREAD-SAFE. -C -C$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: M,N,INCW,INCG,KMAX - REAL,INTENT(IN):: RLON(N) - REAL,INTENT(IN):: W(2*INCW,KMAX) - REAL,INTENT(OUT):: G(INCG,KMAX) - INTEGER I,K,L - REAL RADLON,SLON(M),CLON(M) - REAL,PARAMETER:: PI=3.14159265358979 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - DO I=1,N - RADLON=PI/180*RLON(I) - DO L=1,M - SLON(L)=SIN(L*RADLON) - CLON(L)=COS(L*RADLON) - ENDDO - DO K=1,KMAX - G(I,K)=W(1,K) - ENDDO - DO L=1,M - DO K=1,KMAX - G(I,K)=G(I,K)+2.*(W(2*L+1,K)*CLON(L)-W(2*L+2,K)*SLON(L)) - ENDDO - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END SUBROUTINE diff --git a/external/sp/v2.0.2/src/spgradq.f b/external/sp/v2.0.2/src/spgradq.f deleted file mode 100644 index f8bef431f..000000000 --- a/external/sp/v2.0.2/src/spgradq.f +++ /dev/null @@ -1,76 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPGRADQ(I,M,ENN1,ELONN1,EON,EONTOP,Q,QDX,QDY,QDYTOP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPGRADQ COMPUTE GRADIENT IN SPECTRAL SPACE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE HORIZONTAL VECTOR GRADIENT OF A SCALAR FIELD -C IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) AND A IS EARTH RADIUS, -C THEN THE ZONAL GRADIENT OF Q(L,N) IS SIMPLY I*L/A*Q(L,N) -C WHILE THE MERIDIONAL GRADIENT OF Q(L,N) IS COMPUTED AS -C EPS(L,N+1)*(N+2)/A*Q(L,N+1)-EPS(L,N+1)*(N-1)/A*Q(L,N-1). -C EXTRA TERMS ARE COMPUTED OVER TOP OF THE SPECTRAL DOMAIN. -C ADVANTAGE IS TAKEN OF THE FACT THAT EPS(L,L)=0 -C IN ORDER TO VECTORIZE OVER THE ENTIRE SPECTRAL DOMAIN. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPGRADQ(I,M,ENN1,ELONN1,EON,EONTOP,Q,QDX,QDY,QDYTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C ELONN1 - REAL ((M+1)*((I+1)*M+2)/2) L/(N*(N+1))*A -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C Q - REAL ((M+1)*((I+1)*M+2)) SCALAR FIELD -C -C OUTPUT ARGUMENT LIST: -C QDX - REAL ((M+1)*((I+1)*M+2)) ZONAL GRADIENT (TIMES COSLAT) -C QDY - REAL ((M+1)*((I+1)*M+2)) MERID GRADIENT (TIMES COSLAT) -C QDYTOP - REAL (2*(M+1)) MERID GRADIENT (TIMES COSLAT) OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - REAL ENN1((M+1)*((I+1)*M+2)/2),ELONN1((M+1)*((I+1)*M+2)/2) - REAL EON((M+1)*((I+1)*M+2)/2),EONTOP(M+1) - REAL Q((M+1)*((I+1)*M+2)) - REAL QDX((M+1)*((I+1)*M+2)),QDY((M+1)*((I+1)*M+2)) - REAL QDYTOP(2*(M+1)) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TAKE ZONAL AND MERIDIONAL GRADIENTS - K=1 - QDX(2*K-1)=0. - QDX(2*K)=0. - QDY(2*K-1)=EON(K+1)*ENN1(K+1)*Q(2*K+1) - QDY(2*K)=EON(K+1)*ENN1(K+1)*Q(2*K+2) - DO K=2,(M+1)*((I+1)*M+2)/2-1 - QDX(2*K-1)=-ELONN1(K)*ENN1(K)*Q(2*K) - QDX(2*K)=ELONN1(K)*ENN1(K)*Q(2*K-1) - QDY(2*K-1)=EON(K+1)*ENN1(K+1)*Q(2*K+1)-EON(K)*ENN1(K-1)*Q(2*K-3) - QDY(2*K)=EON(K+1)*ENN1(K+1)*Q(2*K+2)-EON(K)*ENN1(K-1)*Q(2*K-2) - ENDDO - K=(M+1)*((I+1)*M+2)/2 - QDX(2*K-1)=-ELONN1(K)*ENN1(K)*Q(2*K) - QDX(2*K)=ELONN1(K)*ENN1(K)*Q(2*K-1) - QDY(2*K-1)=-EON(K)*ENN1(K-1)*Q(2*K-3) - QDY(2*K)=-EON(K)*ENN1(K-1)*Q(2*K-2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TAKE MERIDIONAL GRADIENT OVER TOP - DO L=0,M - K=L*(2*M+(I-1)*(L-1))/2+I*L+M+1 - QDYTOP(2*L+1)=-EONTOP(L+1)*ENN1(K)*Q(2*K-1) - QDYTOP(2*L+2)=-EONTOP(L+1)*ENN1(K)*Q(2*K) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/spgradx.f b/external/sp/v2.0.2/src/spgradx.f deleted file mode 100644 index 911d8e2b6..000000000 --- a/external/sp/v2.0.2/src/spgradx.f +++ /dev/null @@ -1,86 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPGRADX(M,INCW,KMAX,MP,CLAT,W,WX) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPGRADX COMPUTE X-GRADIENT IN FOURIER SPACE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-20 -C -C ABSTRACT: THIS SUBPROGRAM COMPUTES THE X-GRADIENT OF FIELDS -C IN COMPLEX FOURIER SPACE. -C THE X-GRADIENT OF A VECTOR FIELD W IS -C WX=CONJG(W)*L/RERTH -C WHERE L IS THE WAVENUMBER AND RERTH IS THE EARTH RADIUS, -C SO THAT THE RESULT IS THE X-GRADIENT OF THE PSEUDO-VECTOR. -C THE X-GRADIENT OF A SCALAR FIELD W IS -C WX=CONJG(W)*L/(RERTH*CLAT) -C WHERE CLAT IS THE COSINE OF LATITUDE. -C AT THE POLE THIS IS UNDEFINED, SO THE WAY TO GET -C THE X-GRADIENT AT THE POLE IS BY PASSING BOTH -C THE WEIGHTED WAVENUMBER 0 AND THE UNWEIGHTED WAVENUMBER 1 -C AMPLITUDES AT THE POLE AND SETTING MP=10. -C IN THIS CASE, THE WAVENUMBER 1 AMPLITUDES ARE USED -C TO COMPUTE THE X-GRADIENT AND THEN ZEROED OUT. -C -C PROGRAM HISTORY LOG: -C 1998-12-18 IREDELL -C -C USAGE: CALL SPGRADX(M,INCW,KMAX,W,WX) -C -C INPUT ARGUMENT LIST: -C M - INTEGER FOURIER WAVENUMBER TRUNCATION -C INCW - INTEGER FIRST DIMENSION OF THE COMPLEX AMPLITUDE ARRAY -C (INCW >= M+1) -C KMAX - INTEGER NUMBER OF FOURIER FIELDS -C MP - INTEGER (KM) IDENTIFIERS -C (0 OR 10 FOR SCALAR, 1 FOR VECTOR) -C CLAT - REAL COSINE OF LATITUDE -C W - COMPLEX(INCW,KMAX) FOURIER AMPLITUDES -C -C OUTPUT ARGUMENT LIST: -C W - COMPLEX(INCW,KMAX) FOURIER AMPLITUDES -C CORRECTED WHEN MP=10 AND CLAT=0 -C WX - COMPLEX(INCW,KMAX) COMPLEX AMPLITUDES OF X-GRADIENTS -C -C SUBPROGRAMS CALLED: -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C REMARKS: -C THIS SUBPROGRAM IS THREAD-SAFE. -C -C$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: M,INCW,KMAX,MP(KMAX) - REAL,INTENT(IN):: CLAT - REAL,INTENT(INOUT):: W(2*INCW,KMAX) - REAL,INTENT(OUT):: WX(2*INCW,KMAX) - INTEGER K,L - REAL,PARAMETER:: RERTH=6.3712E6 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - DO K=1,KMAX - IF(MP(K).EQ.1) THEN - DO L=0,M - WX(2*L+1,K)=-W(2*L+2,K)*(L/RERTH) - WX(2*L+2,K)=+W(2*L+1,K)*(L/RERTH) - ENDDO - ELSEIF(CLAT.EQ.0.) THEN - DO L=0,M - WX(2*L+1,K)=0 - WX(2*L+2,K)=0 - ENDDO - IF(MP(K).EQ.10.AND.M.GE.2) THEN - WX(3,K)=-W(4,K)/RERTH - WX(4,K)=+W(3,K)/RERTH - W(3,K)=0 - W(4,K)=0 - ENDIF - ELSE - DO L=0,M - WX(2*L+1,K)=-W(2*L+2,K)*(L/(RERTH*CLAT)) - WX(2*L+2,K)=+W(2*L+1,K)*(L/(RERTH*CLAT)) - ENDDO - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END SUBROUTINE diff --git a/external/sp/v2.0.2/src/spgrady.f b/external/sp/v2.0.2/src/spgrady.f deleted file mode 100644 index 5a77922ba..000000000 --- a/external/sp/v2.0.2/src/spgrady.f +++ /dev/null @@ -1,67 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPGRADY(I,M,ENN1,EON,EONTOP,Q,QDY,QDYTOP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPGRADY COMPUTE Y-GRADIENT IN SPECTRAL SPACE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE HORIZONTAL VECTOR Y-GRADIENT OF A SCALAR FIELD -C IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) AND A IS EARTH RADIUS, -C THEN THE MERIDIONAL GRADIENT OF Q(L,N) IS COMPUTED AS -C EPS(L,N+1)*(N+2)/A*Q(L,N+1)-EPS(L,N+1)*(N-1)/A*Q(L,N-1). -C EXTRA TERMS ARE COMPUTED OVER TOP OF THE SPECTRAL DOMAIN. -C ADVANTAGE IS TAKEN OF THE FACT THAT EPS(L,L)=0 -C IN ORDER TO VECTORIZE OVER THE ENTIRE SPECTRAL DOMAIN. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPGRADY(I,M,ENN1,EON,EONTOP,Q,QDY,QDYTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C Q - REAL ((M+1)*((I+1)*M+2)) SCALAR FIELD -C -C OUTPUT ARGUMENT LIST: -C QDY - REAL ((M+1)*((I+1)*M+2)) MERID GRADIENT (TIMES COSLAT) -C QDYTOP - REAL (2*(M+1)) MERID GRADIENT (TIMES COSLAT) OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - REAL ENN1((M+1)*((I+1)*M+2)/2) - REAL EON((M+1)*((I+1)*M+2)/2),EONTOP(M+1) - REAL Q((M+1)*((I+1)*M+2)) - REAL QDY((M+1)*((I+1)*M+2)) - REAL QDYTOP(2*(M+1)) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TAKE MERIDIONAL GRADIENT - K=1 - QDY(2*K-1)=EON(K+1)*ENN1(K+1)*Q(2*K+1) - QDY(2*K)=EON(K+1)*ENN1(K+1)*Q(2*K+2) - DO K=2,(M+1)*((I+1)*M+2)/2-1 - QDY(2*K-1)=EON(K+1)*ENN1(K+1)*Q(2*K+1)-EON(K)*ENN1(K-1)*Q(2*K-3) - QDY(2*K)=EON(K+1)*ENN1(K+1)*Q(2*K+2)-EON(K)*ENN1(K-1)*Q(2*K-2) - ENDDO - K=(M+1)*((I+1)*M+2)/2 - QDY(2*K-1)=-EON(K)*ENN1(K-1)*Q(2*K-3) - QDY(2*K)=-EON(K)*ENN1(K-1)*Q(2*K-2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TAKE MERIDIONAL GRADIENT OVER TOP - DO L=0,M - K=L*(2*M+(I-1)*(L-1))/2+I*L+M+1 - QDYTOP(2*L+1)=-EONTOP(L+1)*ENN1(K)*Q(2*K-1) - QDYTOP(2*L+2)=-EONTOP(L+1)*ENN1(K)*Q(2*K) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/splaplac.f b/external/sp/v2.0.2/src/splaplac.f deleted file mode 100644 index 5ee7eed58..000000000 --- a/external/sp/v2.0.2/src/splaplac.f +++ /dev/null @@ -1,61 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPLAPLAC(I,M,ENN1,Q,QD2,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE LAPLACIAN OR THE INVERSE LAPLACIAN -C OF A SCALAR FIELD IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C THE LAPLACIAN OF Q(L,N) IS SIMPLY -N*(N+1)/A**2*Q(L,N) -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPLAPLAC(I,M,ENN1,Q,QD2,IDIR) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C Q - IF IDIR > 0, REAL ((M+1)*((I+1)*M+2)) SCALAR FIELD -C QD2 - IF IDIR < 0, REAL ((M+1)*((I+1)*M+2)) LAPLACIAN -C IDIR - INTEGER FLAG -C IDIR > 0 TO TAKE LAPLACIAN -C IDIR < 0 TO TAKE INVERSE LAPLACIAN -C -C OUTPUT ARGUMENT LIST: -C Q - IF IDIR < 0, REAL ((M+1)*((I+1)*M+2)) SCALAR FIELD -C (Q(0,0) IS NOT COMPUTED) -C QD2 - IF IDIR > 0, REAL ((M+1)*((I+1)*M+2)) LAPLACIAN -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - REAL ENN1((M+1)*((I+1)*M+2)/2) - REAL Q((M+1)*((I+1)*M+2)) - REAL QD2((M+1)*((I+1)*M+2)) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TAKE LAPLACIAN - IF(IDIR.GT.0) THEN - K=1 - QD2(2*K-1)=0. - QD2(2*K)=0. - DO K=2,(M+1)*((I+1)*M+2)/2 - QD2(2*K-1)=Q(2*K-1)*(-ENN1(K)) - QD2(2*K)=Q(2*K)*(-ENN1(K)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TAKE INVERSE LAPLACIAN - ELSE - DO K=2,(M+1)*((I+1)*M+2)/2 - Q(2*K-1)=QD2(2*K-1)/(-ENN1(K)) - Q(2*K)=QD2(2*K)/(-ENN1(K)) - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/splat.F b/external/sp/v2.0.2/src/splat.F deleted file mode 100644 index 604072a60..000000000 --- a/external/sp/v2.0.2/src/splat.F +++ /dev/null @@ -1,213 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPLAT(IDRT,JMAX,SLAT,WLAT) -C SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPLAT COMPUTE LATITUDE FUNCTIONS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-20 -C -C ABSTRACT: COMPUTES COSINES OF COLATITUDE AND GAUSSIAN WEIGHTS -C FOR ONE OF THE FOLLOWING SPECIFIC GLOBAL SETS OF LATITUDES. -C GAUSSIAN LATITUDES (IDRT=4) -C EQUALLY-SPACED LATITUDES INCLUDING POLES (IDRT=0) -C EQUALLY-SPACED LATITUDES EXCLUDING POLES (IDRT=256) -C THE GAUSSIAN LATITUDES ARE LOCATED AT THE ZEROES OF THE -C LEGENDRE POLYNOMIAL OF THE GIVEN ORDER. THESE LATITUDES -C ARE EFFICIENT FOR REVERSIBLE TRANSFORMS FROM SPECTRAL SPACE. -C (ABOUT TWICE AS MANY EQUALLY-SPACED LATITUDES ARE NEEDED.) -C THE WEIGHTS FOR THE EQUALLY-SPACED LATITUDES ARE BASED ON -C ELLSAESSER (JAM,1966). (NO WEIGHT IS GIVEN THE POLE POINT.) -C NOTE THAT WHEN ANALYZING GRID TO SPECTRAL IN LATITUDE PAIRS, -C IF AN EQUATOR POINT EXISTS, ITS WEIGHT SHOULD BE HALVED. -C THIS VERSION INVOKES THE IBM ESSL MATRIX SOLVER. -C -C PROGRAM HISTORY LOG: -C 96-02-20 IREDELL -C 97-10-20 IREDELL ADJUST PRECISION -C 98-06-11 IREDELL GENERALIZE PRECISION USING FORTRAN 90 INTRINSIC -C 1998-12-03 IREDELL GENERALIZE PRECISION FURTHER -C 1998-12-03 IREDELL USES AIX ESSL BLAS CALLS -C 2009-12-27 DSTARK updated to switch between ESSL calls on an AIX -C platform, and Numerical Recipies calls elsewise. -C 2010-12-30 SLOVACEK update alignment so preprocessor does not cause -C compilation failure -C 2012-09-01 E.Mirvis & M.Iredell merging & debugging linux errors -C of _d and _8 using generic LU factorization. -C 2012-11-05 E.Mirvis generic FFTPACK and LU lapack were removed -C---------------------------------------------------------------- -C USAGE: CALL SPLAT(IDRT,JMAX,SLAT,WLAT) -C -C INPUT ARGUMENT LIST: -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C JMAX - INTEGER NUMBER OF LATITUDES. -C -C OUTPUT ARGUMENT LIST: -C SLAT - REAL (JMAX) SINES OF LATITUDE. -C WLAT - REAL (JMAX) GAUSSIAN WEIGHTS. -C -C SUBPROGRAMS CALLED: -C DGEF MATRIX FACTORIZATION - ESSL -C DGES MATRIX SOLVER - ESSL -C LUDCMP LU factorization - numerical recipies -C LUBKSB Matrix solver - numerical recipies -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C - REAL SLAT(JMAX),WLAT(JMAX) - INTEGER,PARAMETER:: KD=SELECTED_REAL_KIND(15,45) - REAL(KIND=KD):: PK(JMAX/2),PKM1(JMAX/2),PKM2(JMAX/2) - REAL(KIND=KD):: SLATD(JMAX/2),SP,SPMAX,EPS=10.*EPSILON(SP) - PARAMETER(JZ=50) - REAL BZ(JZ) - DATA BZ / 2.4048255577, 5.5200781103, - $ 8.6537279129, 11.7915344391, 14.9309177086, 18.0710639679, - $ 21.2116366299, 24.3524715308, 27.4934791320, 30.6346064684, - $ 33.7758202136, 36.9170983537, 40.0584257646, 43.1997917132, - $ 46.3411883717, 49.4826098974, 52.6240518411, 55.7655107550, - $ 58.9069839261, 62.0484691902, 65.1899648002, 68.3314693299, - $ 71.4729816036, 74.6145006437, 77.7560256304, 80.8975558711, - $ 84.0390907769, 87.1806298436, 90.3221726372, 93.4637187819, - $ 96.6052679510, 99.7468198587, 102.888374254, 106.029930916, - $ 109.171489649, 112.313050280, 115.454612653, 118.596176630, - $ 121.737742088, 124.879308913, 128.020877005, 131.162446275, - $ 134.304016638, 137.445588020, 140.587160352, 143.728733573, - $ 146.870307625, 150.011882457, 153.153458019, 156.295034268 / - REAL:: DLT,D1=1. - REAL AWORK((JMAX+1)/2,((JMAX+1)/2)),BWORK(((JMAX+1)/2)) - INTEGER:: JHE,JHO,J0=0 - INTEGER IPVT((JMAX+1)/2) - PARAMETER(PI=3.14159265358979,C=(1.-(2./PI)**2)*0.25) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GAUSSIAN LATITUDES - IF(IDRT.EQ.4) THEN - JH=JMAX/2 - JHE=(JMAX+1)/2 - R=1./SQRT((JMAX+0.5)**2+C) - DO J=1,MIN(JH,JZ) - SLATD(J)=COS(BZ(J)*R) - ENDDO - DO J=JZ+1,JH - SLATD(J)=COS((BZ(JZ)+(J-JZ)*PI)*R) - ENDDO - SPMAX=1. - DO WHILE(SPMAX.GT.EPS) - SPMAX=0. - DO J=1,JH - PKM1(J)=1. - PK(J)=SLATD(J) - ENDDO - DO N=2,JMAX - DO J=1,JH - PKM2(J)=PKM1(J) - PKM1(J)=PK(J) - PK(J)=((2*N-1)*SLATD(J)*PKM1(J)-(N-1)*PKM2(J))/N - ENDDO - ENDDO - DO J=1,JH - SP=PK(J)*(1.-SLATD(J)**2)/(JMAX*(PKM1(J)-SLATD(J)*PK(J))) - SLATD(J)=SLATD(J)-SP - SPMAX=MAX(SPMAX,ABS(SP)) - ENDDO - ENDDO -CDIR$ IVDEP - DO J=1,JH - SLAT(J)=SLATD(J) - WLAT(J)=(2.*(1.-SLATD(J)**2))/(JMAX*PKM1(J))**2 - SLAT(JMAX+1-J)=-SLAT(J) - WLAT(JMAX+1-J)=WLAT(J) - ENDDO - IF(JHE.GT.JH) THEN - SLAT(JHE)=0. - WLAT(JHE)=2./JMAX**2 - DO N=2,JMAX,2 - WLAT(JHE)=WLAT(JHE)*N**2/(N-1)**2 - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C EQUALLY-SPACED LATITUDES INCLUDING POLES - ELSEIF(IDRT.EQ.0) THEN - JH=JMAX/2 - JHE=(JMAX+1)/2 - JHO=JHE-1 - DLT=PI/(JMAX-1) - SLAT(1)=1. - DO J=2,JH - SLAT(J)=COS((J-1)*DLT) - ENDDO - DO JS=1,JHO - DO J=1,JHO - AWORK(JS,J)=COS(2*(JS-1)*J*DLT) - ENDDO - ENDDO - DO JS=1,JHO - BWORK(JS)=-D1/(4*(JS-1)**2-1) - ENDDO -#if IBM4 || IBM8 - CALL DGEF(AWORK,JHE,JHO,IPVT) - CALL DGES(AWORK,JHE,JHO,IPVT,BWORK,J0) -#endif -#if LINUX - call ludcmp(awork,jho,jhe,ipvt) - call lubksb(awork,jho,jhe,ipvt,bwork) -#endif - WLAT(1)=0. - DO J=1,JHO - WLAT(J+1)=BWORK(J) - ENDDO -CDIR$ IVDEP - DO J=1,JH - SLAT(JMAX+1-J)=-SLAT(J) - WLAT(JMAX+1-J)=WLAT(J) - ENDDO - IF(JHE.GT.JH) THEN - SLAT(JHE)=0. - WLAT(JHE)=2.*WLAT(JHE) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C EQUALLY-SPACED LATITUDES EXCLUDING POLES - ELSEIF(IDRT.EQ.256) THEN - JH=JMAX/2 - JHE=(JMAX+1)/2 - JHO=JHE - DLT=PI/JMAX - SLAT(1)=1. - DO J=1,JH - SLAT(J)=COS((J-0.5)*DLT) - ENDDO - DO JS=1,JHO - DO J=1,JHO - AWORK(JS,J)=COS(2*(JS-1)*(J-0.5)*DLT) - ENDDO - ENDDO - DO JS=1,JHO - BWORK(JS)=-D1/(4*(JS-1)**2-1) - ENDDO -#if IBM4 || IBM8 - CALL DGEF(AWORK,JHE,JHO,IPVT) - CALL DGES(AWORK,JHE,JHO,IPVT,BWORK,J0) -#endif -#if LINUX - call ludcmp(awork,jho,jhe,ipvt,d) - call lubksb(awork,jho,jhe,ipvt,bwork) -#endif - WLAT(1)=0. - DO J=1,JHO - WLAT(J)=BWORK(J) - ENDDO -CDIR$ IVDEP - DO J=1,JH - SLAT(JMAX+1-J)=-SLAT(J) - WLAT(JMAX+1-J)=WLAT(J) - ENDDO - IF(JHE.GT.JH) THEN - SLAT(JHE)=0. - WLAT(JHE)=2.*WLAT(JHE) - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/splegend.f b/external/sp/v2.0.2/src/splegend.f deleted file mode 100644 index d8b1bccd4..000000000 --- a/external/sp/v2.0.2/src/splegend.f +++ /dev/null @@ -1,134 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPLEGEND(I,M,SLAT,CLAT,EPS,EPSTOP,PLN,PLNTOP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: EVALUATES THE ORTHONORMAL ASSOCIATED LEGENDRE POLYNOMIALS -C IN THE SPECTRAL DOMAIN AT A GIVEN LATITUDE. -C SUBPROGRAM SPLEGEND SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C AND EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) THEN -C THE FOLLOWING BOOTSTRAPPING FORMULAS ARE USED: -C PLN(0,0)=SQRT(0.5) -C PLN(L,L)=PLN(L-1,L-1)*CLAT*SQRT(FLOAT(2*L+1)/FLOAT(2*L)) -C PLN(L,N)=(SLAT*PLN(L,N-1)-EPS(L,N-1)*PLN(L,N-2))/EPS(L,N) -C SYNTHESIS AT THE POLE NEEDS ONLY TWO ZONAL WAVENUMBERS. -C SCALAR FIELDS ARE SYNTHESIZED WITH ZONAL WAVENUMBER 0 WHILE -C VECTOR FIELDS ARE SYNTHESIZED WITH ZONAL WAVENUMBER 1. -C (THUS POLAR VECTOR FIELDS ARE IMPLICITLY DIVIDED BY CLAT.) -C THE FOLLOWING BOOTSTRAPPING FORMULAS ARE USED AT THE POLE: -C PLN(0,0)=SQRT(0.5) -C PLN(1,1)=SQRT(0.75) -C PLN(L,N)=(PLN(L,N-1)-EPS(L,N-1)*PLN(L,N-2))/EPS(L,N) -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C 98-06-10 MARK IREDELL GENERALIZE PRECISION -C -C USAGE: CALL SPLEGEND(I,M,SLAT,CLAT,EPS,EPSTOP,PLN,PLNTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C SLAT - REAL SINE OF LATITUDE -C CLAT - REAL COSINE OF LATITUDE -C EPS - REAL ((M+1)*((I+1)*M+2)/2) SQRT((N**2-L**2)/(4*N**2-1)) -C EPSTOP - REAL (M+1) SQRT((N**2-L**2)/(4*N**2-1)) OVER TOP -C -C OUTPUT ARGUMENT LIST: -C PLN - REAL ((M+1)*((I+1)*M+2)/2) LEGENDRE POLYNOMIAL -C PLNTOP - REAL (M+1) LEGENDRE POLYNOMIAL OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -CFPP$ NOCONCUR R - REAL EPS((M+1)*((I+1)*M+2)/2),EPSTOP(M+1) - REAL PLN((M+1)*((I+1)*M+2)/2),PLNTOP(M+1) - REAL(KIND=SELECTED_REAL_KIND(15,45)):: DLN((M+1)*((I+1)*M+2)/2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C ITERATIVELY COMPUTE PLN WITHIN SPECTRAL DOMAIN AT POLE - M1=M+1 - M2=2*M+I+1 - MX=(M+1)*((I+1)*M+2)/2 - IF(CLAT.EQ.0.) THEN - DLN(1)=SQRT(0.5) - IF(M.GT.0) THEN - DLN(M1+1)=SQRT(0.75) - DLN(2)=SLAT*DLN(1)/EPS(2) - ENDIF - IF(M.GT.1) THEN - DLN(M1+2)=SLAT*DLN(M1+1)/EPS(M1+2) - DLN(3)=(SLAT*DLN(2)-EPS(2)*DLN(1))/EPS(3) - DO N=3,M - K=1+N - DLN(K)=(SLAT*DLN(K-1)-EPS(K-1)*DLN(K-2))/EPS(K) - K=M1+N - DLN(K)=(SLAT*DLN(K-1)-EPS(K-1)*DLN(K-2))/EPS(K) - ENDDO - IF(I.EQ.1) THEN - K=M2 - DLN(K)=(SLAT*DLN(K-1)-EPS(K-1)*DLN(K-2))/EPS(K) - ENDIF - DO K=M2+1,MX - DLN(K)=0. - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE POLYNOMIALS OVER TOP OF SPECTRAL DOMAIN - K=M1+1 - PLNTOP(1)=(SLAT*DLN(K-1)-EPS(K-1)*DLN(K-2))/EPSTOP(1) - IF(M.GT.0) THEN - K=M2+1 - PLNTOP(2)=(SLAT*DLN(K-1)-EPS(K-1)*DLN(K-2))/EPSTOP(2) - DO L=2,M - PLNTOP(L+1)=0. - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C ITERATIVELY COMPUTE PLN(L,L) (BOTTOM HYPOTENUSE OF DOMAIN) - ELSE - NML=0 - K=1 - DLN(K)=SQRT(0.5) - DO L=1,M+(I-1)*NML - KP=K - K=L*(2*M+(I-1)*(L-1))/2+L+NML+1 - DLN(K)=DLN(KP)*CLAT*SQRT(FLOAT(2*L+1)/FLOAT(2*L)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE PLN(L,L+1) (DIAGONAL NEXT TO BOTTOM HYPOTENUSE OF DOMAIN) - NML=1 -CDIR$ IVDEP - DO L=0,M+(I-1)*NML - K=L*(2*M+(I-1)*(L-1))/2+L+NML+1 - DLN(K)=SLAT*DLN(K-1)/EPS(K) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE REMAINING PLN IN SPECTRAL DOMAIN - DO NML=2,M -CDIR$ IVDEP - DO L=0,M+(I-1)*NML - K=L*(2*M+(I-1)*(L-1))/2+L+NML+1 - DLN(K)=(SLAT*DLN(K-1)-EPS(K-1)*DLN(K-2))/EPS(K) - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE POLYNOMIALS OVER TOP OF SPECTRAL DOMAIN - DO L=0,M - NML=M+1+(I-1)*L - K=L*(2*M+(I-1)*(L-1))/2+L+NML+1 - PLNTOP(L+1)=(SLAT*DLN(K-1)-EPS(K-1)*DLN(K-2))/EPSTOP(L+1) - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C RETURN VALUES - DO K=1,MX - PLN(K)=DLN(K) - ENDDO - RETURN - END diff --git a/external/sp/v2.0.2/src/splib.doc b/external/sp/v2.0.2/src/splib.doc deleted file mode 100644 index 5db4205af..000000000 --- a/external/sp/v2.0.2/src/splib.doc +++ /dev/null @@ -1,2621 +0,0 @@ -Documentation of the spectral transform library splib May 2, 1996 --------------------------------------------------------------------------------- - -I. Introduction - -The spectral transform library splib contains FORTRAN subprograms -to be used for a variety of spectral transform functions. -The library has been optimized for the CRAY machines, taking full advantage -of both the vector and parallel capabilities. The library is particularly -efficient when transforming many fields at one time. Some entry points -will diagnose the environmental number of CPUs available, but others require -the number of CPUs used be specified. The library is reasonably transportable -to other platforms with compilers allowing dynamic automatic arrays. - -The library can handle both scalar and two-dimensional vector fields. -Each vector field will be represented in spectral space appropriately -by its respective spherical divergence and curl (vorticity), thus -avoiding the pole problems associated with representing components separately. - -Some of the functions performed by the library are spectral interpolations -between two grids, spectral truncations in place on a grid, and basic -spectral transforms between grid and wave space. Only global Gaussian -or global equidistant cylindrical grids are allowed for transforming into -wave space. There are no such restricitions on grids for transforming from -wave space. However, there are special fast entry points for transforming wave -space to polar stereographic and Mercator grids as well as the aforementioned -cylindrical grids. - -The indexing of the cylindrical transform grids is totally general. -The grids may run north to south or south to north; they may run east to west -or west to east; they may start at any longitude as long as the prime meridian -is on the grid; they may be dimensioned in any order (e.g. (i,j,k), (k,j,i), -(i,k,nfield,j), etc.). Furthermore, the transform may be performed on only -some of the latitudes at one time as long as both hemisphere counterparts -are transformed at the same time (as in the global spectral model). -The grid indexing will default to the customary global indexing, i.e. north to -south, east to west, prime meridian as first longitude, and (i,j,k) order. - -The wave space may be either triangular or rhomboidal in shape. -Its internal indexing is strictly "IBM order", i.e. zonal wavenumber is the -slower index with the real and imaginary components always paired together. -The imaginary components of all the zonally symmetric modes should always -be zero, as should the global mean of any divergence and vorticity fields. -The stride between the start of successive wave fields is general, -defaulting to the computed length of each field. - -This documentation is divided into 4 chapters. Chapter I is this introduction. -Chapter II is a list of all entry points. Chapter III is a set of examples. -Chapter IV is a recapitulation of all the docblocks. The chapters all start -on a line number that is 1 modulo 60 in order to facilitate laser printing. - - - - - - - - - - -II. Entry point list - - Name Function - ---- ------------------------------------------------------------------ - - Spectral interpolations or truncations between grid and grid - - SPTRUN SPECTRALLY TRUNCATE GRIDDED SCALAR FIELDS - SPTRUNV SPECTRALLY TRUNCATE GRIDDED VECTOR FIELDS - SPTRUNG SPECTRALLY INTERPOLATE SCALARS TO STATIONS - SPTRUNGV SPECTRALLY INTERPOLATE VECTORS TO STATIONS - SPTRUNS SPECTRALLY INTERPOLATE SCALARS TO POLAR STEREO - SPTRUNSV SPECTRALLY INTERPOLATE VECTORS TO POLAR STEREO - SPTRUNM SPECTRALLY INTERPOLATE SCALARS TO MERCATOR - SPTRUNMV SPECTRALLY INTERPOLATE VECTORS TO MERCATOR - - Spectral transforms between wave and grid - - SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM - SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM - SPTRAND PERFORM A GRADIENT SPHERICAL TRANSFORM - SPTGPT TRANSFORM SPECTRAL SCALAR TO STATION POINTS - SPTGPTV TRANSFORM SPECTRAL VECTOR TO STATION POINTS - SPTGPTD TRANSFORM SPECTRAL TO STATION POINT GRADIENTS - SPTGPS TRANSFORM SPECTRAL SCALAR TO POLAR STEREO - SPTGPSV TRANSFORM SPECTRAL VECTOR TO POLAR STEREO - SPTGPSD TRANSFORM SPECTRAL TO POLAR STEREO GRADIENTS - SPTGPM TRANSFORM SPECTRAL SCALAR TO MERCATOR - SPTGPMV TRANSFORM SPECTRAL VECTOR TO MERCATOR - SPTGPMD TRANSFORM SPECTRAL TO MERCATOR GRADIENTS - - Spectral transform utilities - - SPGGET GET GRID-SPACE CONSTANTS - SPWGET GET WAVE-SPACE CONSTANTS - SPLAT COMPUTE LATITUDE FUNCTIONS - SPEPS COMPUTE UTILITY SPECTRAL FIELDS - SPLEGEND COMPUTE LEGENDRE POLYNOMIALS - SPANALY ANALYZE SPECTRAL FROM FOURIER - SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL - SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY - SPUV2DZ COMPUTE DIVERGENCE AND VORTICITY FROM WINDS - SPGRADQ COMPUTE GRADIENT IN SPECTRAL SPACE - SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE - - - - - - - - - - - - - - - - -III. Examples - -Example 1. Interpolate heights and winds from a latlon grid - to two antipodal polar stereographic grids. - Subprograms GETGB and PUTGB from w3lib are referenced. - -c unit number 11 is the input latlon grib file -c unit number 31 is the input latlon grib index file -c unit number 51 is the output northern polar stereographic grib file -c unit number 52 is the output southern polar stereographic grib file -c nominal spectral truncation is r40 -c maximum input gridsize is 360x181 -c maximum number of levels wanted is 12 - parameter(lug=11,lui=31,lun=51,lus=52) - parameter(iromb=1,maxwv=40,jf=360*181,kx=12) - integer kp5(kx),kp6(kx),kp7(kx) - integer kpo(kx) - data kpo/1000,850,700,500,400,300,250,200,150,100,70,50/ -c height - km=12 - kp5=7 - kp6=100 - kp7=kpo - call gs65(lug,lui,lun,lus,jf,km,kp5,kp6,kp7,iromb,maxwv) -c winds - km=12 - kp5=33 - kp6=100 - kp7=kpo - call gv65(lug,lui,lun,lus,jf,km,kp5,kp6,kp7,iromb,maxwv) -c - stop - end -c - subroutine gs65(lug,lui,lun,lus,jf,km,kp5,kp6,kp7,iromb,maxwv) -c interpolates a scalar field using spectral transforms. - integer kp5(km),kp6(km),kp7(km) -c output grids are 65x65 (381 km true at latitide 60). -c nh grid oriented at 280E; sh grid oriented at 100E. - parameter(nph=32,nps=2*nph+1,npq=nps*nps) - parameter(true=60.,xmesh=381.e3,orient=280.) - parameter(rerth=6.3712e6) - parameter(pi=3.14159265358979,dpr=180./pi) - real gn(npq,km),gs(npq,km) - integer jpds(25),jgds(22),kpds(25,km),kgds(22,km) - logical lb(jf) - real f(jf,km) -c - g2=((1.+sin(abs(true)/dpr))*rerth/xmesh)**2 - r2=2*nph**2 - rlatn1=dpr*asin((g2-r2)/(g2+r2)) - rlonn1=mod(orient+315,360.) - rlats1=-rlatn1 - rlons1=mod(rlonn1+270,360.) - jpds=-1 - do k=1,km - jpds(5)=kp5(k) - jpds(6)=kp6(k) - jpds(7)=kp7(k) - j=0 - call getgb(lug,lui,jf,j,jpds,jgds,kf,j,kpds(1,k),kgds(1,k), - & lb,f(1,k),iret) - if(iret.ne.0) call exit(1) - if(mod(kpds(4,k)/64,2).eq.1) call exit(2) - enddo - idrt=kgds(1,1) - imax=kgds(2,1) - jmax=kgds(3,1) -c - call sptruns(iromb,maxwv,idrt,imax,jmax,km,nps, - & 0,0,0,jf,0,0,0,0,true,xmesh,orient,f,gn,gs) -c - do k=1,km - kpds(3,k)=27 - kgds(1,k)=5 - kgds(2,k)=nps - kgds(3,k)=nps - kgds(4,k)=nint(rlatn1*1.e3) - kgds(5,k)=nint(rlonn1*1.e3) - kgds(6,k)=8 - kgds(7,k)=nint(orient*1.e3) - kgds(8,k)=nint(xmesh) - kgds(9,k)=nint(xmesh) - kgds(10,k)=0 - kgds(11,k)=64 - call putgb(lun,npq,kpds(1,k),kgds(1,k),lb,gn(1,k),iret) - enddo - do k=1,km - kpds(3,k)=28 - kgds(1,k)=5 - kgds(2,k)=nps - kgds(3,k)=nps - kgds(4,k)=nint(rlats1*1.e3) - kgds(5,k)=nint(rlons1*1.e3) - kgds(6,k)=8 - kgds(7,k)=nint(mod(orient+180,360.)*1.e3) - kgds(8,k)=nint(xmesh) - kgds(9,k)=nint(xmesh) - kgds(10,k)=128 - kgds(11,k)=64 - call putgb(lus,npq,kpds(1,k),kgds(1,k),lb,gs(1,k),iret) - enddo -c - end -c - subroutine gv65(lug,lui,lun,lus,jf,km,kp5,kp6,kp7,iromb,maxwv) -c interpolates a vector field using spectral transforms. - integer kp5(km),kp6(km),kp7(km) -c output grids are 65x65 (381 km true at latitide 60). -c nh grid oriented at 280E; sh grid oriented at 100E. -c winds are rotated to be relative to grid coordinates. - parameter(nph=32,nps=2*nph+1,npq=nps*nps) - parameter(true=60.,xmesh=381.e3,orient=280.) - parameter(rerth=6.3712e6) - parameter(pi=3.14159265358979,dpr=180./pi) - real un(npq,km),vn(npq,km),us(npq,km),vs(npq,km) - integer jpds(25),jgds(22),kpds(25,km),kgds(22,km) - logical lb(jf) - real u(jf,km),v(jf,km) -c - g2=((1.+sin(abs(true)/dpr))*rerth/xmesh)**2 - r2=2*nph**2 - rlatn1=dpr*asin((g2-r2)/(g2+r2)) - rlonn1=mod(orient+315,360.) - rlats1=-rlatn1 - rlons1=mod(rlonn1+270,360.) - jpds=-1 - do k=1,km - jpds(5)=kp5(k) - jpds(6)=kp6(k) - jpds(7)=kp7(k) - j=0 - call getgb(lug,lui,jf,j,jpds,jgds,kf,j,kpds(1,k),kgds(1,k), - & lb,u(1,k),iret) - if(iret.ne.0) call exit(1) - if(mod(kpds(4,k)/64,2).eq.1) call exit(2) - jpds=kpds(:,k) - jgds=kgds(:,k) - jpds(5)=jpds(5)+1 - j=0 - call getgb(lug,lui,jf,j,jpds,jgds,kf,j,kpds(1,k),kgds(1,k), - & lb,v(1,k),iret) - if(iret.ne.0) call exit(1) - if(mod(kpds(4,k)/64,2).eq.1) call exit(2) - enddo - idrt=kgds(1,1) - imax=kgds(2,1) - jmax=kgds(3,1) -c - call sptrunsv(iromb,maxwv,idrt,imax,jmax,km,nps, - & 0,0,0,jf,0,0,0,0,true,xmesh,orient,u,v, - & .true.,un,vn,us,vs,.false.,dum,dum,dum,dum, - & .false.,dum,dum,dum,dum) -c - do k=1,km - kpds(3,k)=27 - kgds(1,k)=5 - kgds(2,k)=nps - kgds(3,k)=nps - kgds(4,k)=nint(rlatn1*1.e3) - kgds(5,k)=nint(rlonn1*1.e3) - kgds(6,k)=8 - kgds(7,k)=nint(orient*1.e3) - kgds(8,k)=nint(xmesh) - kgds(9,k)=nint(xmesh) - kgds(10,k)=0 - kgds(11,k)=64 - kpds(5,k)=kp5(k) - call putgb(lun,npq,kpds(1,k),kgds(1,k),lb,un(1,k),iret) - enddo - do k=1,km - kpds(3,k)=27 - kgds(1,k)=5 - kgds(2,k)=nps - kgds(3,k)=nps - kgds(4,k)=nint(rlatn1*1.e3) - kgds(5,k)=nint(rlonn1*1.e3) - kgds(6,k)=8 - kgds(7,k)=nint(orient*1.e3) - kgds(8,k)=nint(xmesh) - kgds(9,k)=nint(xmesh) - kgds(10,k)=0 - kgds(11,k)=64 - kpds(5,k)=kp5(k)+1 - call putgb(lun,npq,kpds(1,k),kgds(1,k),lb,vn(1,k),iret) - enddo - do k=1,km - kpds(3,k)=28 - kgds(1,k)=5 - kgds(2,k)=nps - kgds(3,k)=nps - kgds(4,k)=nint(rlats1*1.e3) - kgds(5,k)=nint(rlons1*1.e3) - kgds(6,k)=8 - kgds(7,k)=nint(mod(orient+180,360.)*1.e3) - kgds(8,k)=nint(xmesh) - kgds(9,k)=nint(xmesh) - kgds(10,k)=128 - kgds(11,k)=64 - kpds(5,k)=kp5(k) - call putgb(lus,npq,kpds(1,k),kgds(1,k),lb,us(1,k),iret) - enddo - do k=1,km - kpds(3,k)=28 - kgds(1,k)=5 - kgds(2,k)=nps - kgds(3,k)=nps - kgds(4,k)=nint(rlats1*1.e3) - kgds(5,k)=nint(rlons1*1.e3) - kgds(6,k)=8 - kgds(7,k)=nint(mod(orient+180,360.)*1.e3) - kgds(8,k)=nint(xmesh) - kgds(9,k)=nint(xmesh) - kgds(10,k)=128 - kgds(11,k)=64 - kpds(5,k)=kp5(k)+1 - call putgb(lus,npq,kpds(1,k),kgds(1,k),lb,vs(1,k),iret) - enddo -c - end - -Example 2. Spectrally truncate winds in place on a latlon grid. - -c unit number 11 is the input latlon grib file -c unit number 31 is the input latlon grib index file -c unit number 51 is the output latlon grib file -c nominal spectral truncation is r40 -c maximum input gridsize is 360x181 -c maximum number of levels wanted is 12 - parameter(lug=11,lui=31,luo=51) - parameter(iromb=1,maxwv=40,jf=360*181,kx=12) - integer kp5(kx),kp6(kx),kp7(kx) - integer kpo(kx) - data kpo/1000,850,700,500,400,300,250,200,150,100,70,50/ -c winds - km=12 - kp5=33 - kp6=100 - kp7=kpo - call gvr40(lug,lui,luo,jf,km,kp5,kp6,kp7,iromb,maxwv) -c - stop - end -c - subroutine gvr40(lug,lui,luo,jf,km,kp5,kp6,kp7,iromb,maxwv) -c interpolates a vector field using spectral transforms. - integer kp5(km),kp6(km),kp7(km) - integer jpds(25),jgds(22),kpds(25,km),kgds(22,km) - logical lb(jf) - real u(jf,km),v(jf,km) -c - jpds=-1 - do k=1,km - jpds(5)=kp5(k) - jpds(6)=kp6(k) - jpds(7)=kp7(k) - j=0 - call getgb(lug,lui,jf,j,jpds,jgds,kf,j,kpds(1,k),kgds(1,k), - & lb,u(1,k),iret) - if(iret.ne.0) call exit(1) - if(mod(kpds(4,k)/64,2).eq.1) call exit(2) - jpds=kpds(:,k) - jgds=kgds(:,k) - jpds(5)=jpds(5)+1 - j=0 - call getgb(lug,lui,jf,j,jpds,jgds,kf,j,kpds(1,k),kgds(1,k), - & lb,v(1,k),iret) - if(iret.ne.0) call exit(1) - if(mod(kpds(4,k)/64,2).eq.1) call exit(2) - enddo - idrt=kgds(1,1) - imax=kgds(2,1) - jmax=kgds(3,1) -c - call sptrunv(iromb,maxwv,idrt,imax,jmax,idrt,imax,jmax,km, - & 0,0,0,jf,0,0,jf,0,u,v,.true.,u,v, - & .false.,dum,dum,.false.,dum,dum) -c - do k=1,km - kpds(5,k)=kp5(k) - call putgb(luo,kf,kpds(1,k),kgds(1,k),lb,u(1,k),iret) - enddo - do k=1,km - kpds(5,k)=kp5(k)+1 - call putgb(luo,kf,kpds(1,k),kgds(1,k),lb,v(1,k),iret) - enddo -c - end - -Example 3. Compute latlon temperatures from spectral temperatures and - compute latlon winds from spectral divergence and vorticity. - -c unit number 11 is the input sigma file -c unit number 51 is the output latlon file -c nominal spectral truncation is t62 -c output gridsize is 144x73 -c number of levels is 28 - parameter(iromb=0,maxwv=62) - parameter(idrt=0,im=144,jm=73) - parameter(levs=28) - parameter(mx=(maxwv+1)*((iromb+1)*maxwv+2)/2) - real t(mx,levs),d(mx,levs),z(mx,levs) - real tg(im,jm,km),ug(im,jm,km),vg(im,jm,km) -c temperature - do k=1,4 - read(11) - enddo - do k=1,levs - read(11) (t(m,k),m=1,mx) - enddo - call sptran(iromb,maxwv,idrt,im,jm,levs,0,0,0,0,0,0,0,0,1, - & t,tg(1,1,1),tg(1,jm,1),1) - call sptran( - do k=1,levs - write(51) ((tg(i,j,k),i=1,im),j=1,jm) - enddo -c winds - do k=1,levs - read(11) (d(m,k),m=1,mx) - read(11) (z(m,k),m=1,mx) - enddo - call sptranv(iromb,maxwv,idrt,im,jm,levs,0,0,0,0,0,0,0,0,1, - & d,z,ug(1,1,1),ug(1,jm,1),vg(1,1,1),vg(1,jm,1),1) - do k=1,levs - write(51) ((ug(i,j,k),i=1,im),j=1,jm) - write(51) ((vg(i,j,k),i=1,im),j=1,jm) - enddo - end - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -IV. Docblocks - -The primary documentation of splib is via the docblocks in its subprograms. -The following recapitulation of docblocks is current as of May, 1996. - -Docblock for sptrun. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUN SPECTRALLY TRUNCATE GRIDDED SCALAR FIELDS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO A POSSIBLY DIFFERENT GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C EITHER GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,IDRTO,IMAXO,JMAXO, -C & KMAX,IPRIME,ISKIPI,JSKIPI,KSKIPI, -C & ISKIPO,JSKIPO,KSKIPO,JCPU,GRIDI,GRIDO) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C IDRTO - INTEGER OUTPUT GRID IDENTIFIER -C (IDRTO=4 FOR GAUSSIAN GRID, -C IDRTO=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTO=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXO - INTEGER EVEN NUMBER OF OUTPUT LONGITUDES. -C JMAXO - INTEGER NUMBER OF OUTPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C ISKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPO=0) -C JSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXO IF JSKIPO=0) -C KSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT GRID FIELDS -C (DEFAULTS TO IMAXO*JMAXO IF KSKIPO=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GRIDO - REAL (*) OUTPUT GRID FIELDS -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptrunv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNV SPECTRALLY TRUNCATE GRIDDED VECTOR FIELDS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES VECTOR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO A POSSIBLY DIFFERENT GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C EITHER GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI, -C & IDRTO,IMAXO,JMAXO,KMAX, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI, -C & ISKIPO,JSKIPO,KSKIPO,JCPU,GRIDUI,GRIDVI, -C & LUV,GRIDUO,GRIDVO,LDZ,GRIDDO,GRIDZO, -C & LPS,GRIDPO,GRIDSO) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C IDRTO - INTEGER OUTPUT GRID IDENTIFIER -C (IDRTO=4 FOR GAUSSIAN GRID, -C IDRTO=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTO=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXO - INTEGER EVEN NUMBER OF OUTPUT LONGITUDES. -C JMAXO - INTEGER NUMBER OF OUTPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C ISKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPO=0) -C JSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXO IF JSKIPO=0) -C KSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT GRID FIELDS -C (DEFAULTS TO IMAXO*JMAXO IF KSKIPO=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRIDUI - REAL (*) INPUT GRID U-WINDS -C GRIDVI - REAL (*) INPUT GRID V-WINDS -C LUV - LOGICAL FLAG WHETHER TO RETURN WINDS -C LDZ - LOGICAL FLAG WHETHER TO RETURN DIVERGENCE AND VORTICITY -C LPS - LOGICAL FLAG WHETHER TO RETURN POTENTIAL AND STREAMFCN -C OUTPUT ARGUMENTS: -C GRIDUO - REAL (*) OUTPUT U-WINDS IF LUV -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDVO - REAL (*) OUTPUT V-WINDS IF LUV -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDDO - REAL (*) OUTPUT DIVERGENCES IF LDZ -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDZO - REAL (*) OUTPUT VORTICITIES IF LDZ -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDPO - REAL (*) OUTPUT POTENTIALS IF LPS -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDSO - REAL (*) OUTPUT STREAMFCNS IF LPS -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptrung. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNG SPECTRALLY INTERPOLATE SCALARS TO STATIONS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO SPECIFIED SETS OF STATION POINTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID AND POINT FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNG(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NMAX, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NRSKIP,NGSKIP,JCPU,RLAT,RLON,GRIDI,GP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GP - REAL (*) STATION POINT SETS -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTGPT TRANSFORM SPECTRAL SCALAR TO STATION POINTS -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptrungv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNGV SPECTRALLY INTERPOLATE VECTORS TO STATIONS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES VECTORS FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO SPECIFIED SETS OF STATION POINTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID AND POINT FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNGV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NMAX, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NRSKIP,NGSKIP,JCPU,RLAT,RLON,GRIDUI,GRIDVI, -C & LUV,UP,VP,LDZ,DP,ZP,LPS,PP,SP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRIDUI - REAL (*) INPUT GRID U-WINDS -C GRIDVI - REAL (*) INPUT GRID V-WINDS -C LUV - LOGICAL FLAG WHETHER TO RETURN WINDS -C LDZ - LOGICAL FLAG WHETHER TO RETURN DIVERGENCE AND VORTICITY -C LPS - LOGICAL FLAG WHETHER TO RETURN POTENTIAL AND STREAMFCN -C OUTPUT ARGUMENTS: -C UP - REAL (*) STATION U-WINDS IF LUV -C VP - REAL (*) STATION V-WINDS IF LUV -C DP - REAL (*) STATION DIVERGENCES IF LDZ -C ZP - REAL (*) STATION VORTICITIES IF LDZ -C PP - REAL (*) STATION POTENTIALS IF LPS -C SP - REAL (*) STATION STREAMFCNS IF LPS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C SPTGPT TRANSFORM SPECTRAL SCALAR TO STATION POINTS -C SPTGPTV TRANSFORM SPECTRAL VECTOR TO STATION POINTS -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptruns. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNS SPECTRALLY INTERPOLATE SCALARS TO POLAR STEREO -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO SPECIFIC PAIRS OF POLAR STEREOGRAPHIC SCALAR FIELDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNS(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NPS, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NISKIP,NJSKIP,JCPU,TRUE,XMESH,ORIENT, -C & GRIDI,GN,GS) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GN - REAL (*) NORTHERN POLAR STEREOGRAPHIC FIELDS -C GS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC FIELDS -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTGPS TRANSFORM SPECTRAL SCALAR TO POLAR STEREO. -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptrunsv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNSV SPECTRALLY INTERPOLATE VECTORS TO POLAR STEREO -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES VECTOR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO SPECIFIC PAIRS OF POLAR STEREOGRAPHIC SCALAR FIELDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNSV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NPS, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NISKIP,NJSKIP,JCPU,TRUE,XMESH,ORIENT, -C & GRIDUI,GRIDVI, -C & LUV,UN,VN,US,VS,LDZ,DN,ZN,DS,ZS, -C & LPS,PN,SN,PS,SS) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C GRIDUI - REAL (*) INPUT GRID U-WINDS -C GRIDVI - REAL (*) INPUT GRID V-WINDS -C LUV - LOGICAL FLAG WHETHER TO RETURN WINDS -C LDZ - LOGICAL FLAG WHETHER TO RETURN DIVERGENCE AND VORTICITY -C LPS - LOGICAL FLAG WHETHER TO RETURN POTENTIAL AND STREAMFCN -C OUTPUT ARGUMENTS: -C UN - REAL (*) NORTHERN PS U-WINDS IF LUV -C VN - REAL (*) NORTHERN PS V-WINDS IF LUV -C US - REAL (*) SOUTHERN PS U-WINDS IF LUV -C VS - REAL (*) SOUTHERN PS V-WINDS IF LUV -C DN - REAL (*) NORTHERN DIVERGENCES IF LDZ -C ZN - REAL (*) NORTHERN VORTICITIES IF LDZ -C DS - REAL (*) SOUTHERN DIVERGENCES IF LDZ -C ZS - REAL (*) SOUTHERN VORTICITIES IF LDZ -C PN - REAL (*) NORTHERN POTENTIALS IF LPS -C SN - REAL (*) NORTHERN STREAMFCNS IF LPS -C PS - REAL (*) SOUTHERN POTENTIALS IF LPS -C SS - REAL (*) SOUTHERN STREAMFCNS IF LPS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C SPTGPS TRANSFORM SPECTRAL SCALAR TO POLAR STEREO. -C SPTGPSV TRANSFORM SPECTRAL VECTOR TO POLAR STEREO. -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptrunm. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNM SPECTRALLY INTERPOLATE SCALARS TO MERCATOR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNM(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,MI,MJ, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NISKIP,NJSKIP,JCPU,RLAT1,RLON1,DLAT,DLON, -C & GRIDI,GM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GM - REAL (*) MERCATOR FIELDS -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTGPM TRANSFORM SPECTRAL SCALAR TO MERCATOR -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptrunmv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNMV SPECTRALLY INTERPOLATE VECTORS TO MERCATOR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES VECTOR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNMV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,MI,MJ, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NISKIP,NJSKIP,JCPU,RLAT1,RLON1,DLAT,DLON, -C & GRIDUI,GRIDVI,LUV,UM,VM,LDZ,DM,ZM,LPS,PM,SM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO MI*MJ IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO MI IF NJSKIP=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C GRIDUI - REAL (*) INPUT GRID U-WINDS -C GRIDVI - REAL (*) INPUT GRID V-WINDS -C LUV - LOGICAL FLAG WHETHER TO RETURN WINDS -C LDZ - LOGICAL FLAG WHETHER TO RETURN DIVERGENCE AND VORTICITY -C LPS - LOGICAL FLAG WHETHER TO RETURN POTENTIAL AND STREAMFCN -C OUTPUT ARGUMENTS: -C UM - REAL (*) MERCATOR U-WINDS IF LUV -C VM - REAL (*) MERCATOR V-WINDS IF LUV -C DM - REAL (*) MERCATOR DIVERGENCES IF LDZ -C ZM - REAL (*) MERCATOR VORTICITIES IF LDZ -C PM - REAL (*) MERCATOR POTENTIALS IF LPS -C SM - REAL (*) MERCATOR STREAMFCNS IF LPS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C SPTGPM TRANSFORM SPECTRAL SCALAR TO MERCATOR -C SPTGPMV TRANSFORM SPECTRAL VECTOR TO MERCATOR -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptran. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C AND FIELDS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C TRANSFORMS ARE DONE IN LATITUDE PAIRS FOR EFFICIENCY; -C THUS GRID ARRAYS FOR EACH HEMISPHERE MUST BE PASSED. -C IF SO REQUESTED, JUST A SUBSET OF THE LATITUDE PAIRS -C MAY BE TRANSFORMED IN EACH INVOCATION OF THE SUBPROGRAM. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER LATITUDE EXCEPT -C THE TRANSFORM FROM FOURIER TO SPECTRAL IS MULTIPROCESSED -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRAN(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, -C & JBEG,JEND,JCPU, -C & WAVE,GRIDN,GRIDS,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C ISKIP - INTEGER SKIP NUMBER BETWEEN LONGITUDES -C (DEFAULTS TO 1 IF ISKIP=0) -C JNSKIP - INTEGER SKIP NUMBER BETWEEN N.H. LATITUDES FROM NORTH -C (DEFAULTS TO IMAX IF JNSKIP=0) -C JSSKIP - INTEGER SKIP NUMBER BETWEEN S.H. LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAX IF JSSKIP=0) -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO IMAX*JMAX IF KGSKIP=0) -C JBEG - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C (DEFAULTS TO 1 IF JBEG=0) -C (IF JBEG=0 AND IDIR<0, WAVE IS ZEROED BEFORE TRANSFORM) -C JEND - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C (DEFAULTS TO (JMAX+1)/2 IF JEND=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C WAVE - REAL (*) WAVE FIELDS IF IDIR>0 -C GRIDN - REAL (*) N.H. GRID FIELDS (STARTING AT JBEG) IF IDIR<0 -C GRIDS - REAL (*) S.H. GRID FIELDS (STARTING AT JBEG) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (*) WAVE FIELDS IF IDIR<0 -C GRIDN - REAL (*) N.H. GRID FIELDS (STARTING AT JBEG) IF IDIR>0 -C GRIDS - REAL (*) S.H. GRID FIELDS (STARTING AT JBEG) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPGGET GET GRID-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPANALY ANALYZE SPECTRAL FROM FOURIER -C RFFTMLT PERFORM FAST FOURIER TRANSFORM -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptranv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C AND VECTOR FIELDS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C TRANSFORMS ARE DONE IN LATITUDE PAIRS FOR EFFICIENCY; -C THUS GRID ARRAYS FOR EACH HEMISPHERE MUST BE PASSED. -C IF SO REQUESTED, JUST A SUBSET OF THE LATITUDE PAIRS -C MAY BE TRANSFORMED IN EACH INVOCATION OF THE SUBPROGRAM. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER LATITUDE EXCEPT -C THE TRANSFORM FROM FOURIER TO SPECTRAL IS MULTIPROCESSED -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRANV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, -C & JBEG,JEND,JCPU, -C & WAVED,WAVEZ,GRIDUN,GRIDUS,GRIDVN,GRIDVS,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C ISKIP - INTEGER SKIP NUMBER BETWEEN LONGITUDES -C (DEFAULTS TO 1 IF ISKIP=0) -C JNSKIP - INTEGER SKIP NUMBER BETWEEN N.H. LATITUDES FROM NORTH -C (DEFAULTS TO IMAX IF JNSKIP=0) -C JSSKIP - INTEGER SKIP NUMBER BETWEEN S.H. LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAX IF JSSKIP=0) -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO IMAX*JMAX IF KGSKIP=0) -C JBEG - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C (DEFAULTS TO 1 IF JBEG=0) -C (IF JBEG=0 AND IDIR<0, WAVE IS ZEROED BEFORE TRANSFORM) -C JEND - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C (DEFAULTS TO (JMAX+1)/2 IF JEND=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS IF IDIR>0 -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS IF IDIR>0 -C GRIDUN - REAL (*) N.H. GRID U-WINDS (STARTING AT JBEG) IF IDIR<0 -C GRIDUS - REAL (*) S.H. GRID U-WINDS (STARTING AT JBEG) IF IDIR<0 -C GRIDVN - REAL (*) N.H. GRID V-WINDS (STARTING AT JBEG) IF IDIR<0 -C GRIDVS - REAL (*) S.H. GRID V-WINDS (STARTING AT JBEG) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS IF IDIR<0 -C [WAVED=(D(GRIDU)/DLAM+D(CLAT*GRIDV)/DPHI)/(CLAT*RERTH)] -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS IF IDIR<0 -C [WAVEZ=(D(GRIDV)/DLAM-D(CLAT*GRIDU)/DPHI)/(CLAT*RERTH)] -C GRIDUN - REAL (*) N.H. GRID U-WINDS (STARTING AT JBEG) IF IDIR>0 -C GRIDUS - REAL (*) S.H. GRID U-WINDS (STARTING AT JBEG) IF IDIR>0 -C GRIDVN - REAL (*) N.H. GRID V-WINDS (STARTING AT JBEG) IF IDIR>0 -C GRIDVS - REAL (*) S.H. GRID V-WINDS (STARTING AT JBEG) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPGGET GET GRID-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPANALY ANALYZE SPECTRAL FROM FOURIER -C RFFTMLT PERFORM FAST FOURIER TRANSFORM -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C SPUV2DZ COMPUTE DIVERGENCE AND VORTICITY FROM WINDS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptrand. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRAND PERFORM A GRADIENT SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C AND THEIR MEANS AND GRADIENTS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C TRANSFORMS ARE DONE IN LATITUDE PAIRS FOR EFFICIENCY; -C THUS GRID ARRAYS FOR EACH HEMISPHERE MUST BE PASSED. -C IF SO REQUESTED, JUST A SUBSET OF THE LATITUDE PAIRS -C MAY BE TRANSFORMED IN EACH INVOCATION OF THE SUBPROGRAM. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER LATITUDE EXCEPT -C THE TRANSFORM FROM FOURIER TO SPECTRAL IS MULTIPROCESSED -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRAND(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, -C & JBEG,JEND,JCPU, -C & WAVE,GRIDMN,GRIDXN,GRIDXS,GRIDYN,GRIDYS,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C ISKIP - INTEGER SKIP NUMBER BETWEEN LONGITUDES -C (DEFAULTS TO 1 IF ISKIP=0) -C JNSKIP - INTEGER SKIP NUMBER BETWEEN N.H. LATITUDES FROM NORTH -C (DEFAULTS TO IMAX IF JNSKIP=0) -C JSSKIP - INTEGER SKIP NUMBER BETWEEN S.H. LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAX IF JSSKIP=0) -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO IMAX*JMAX IF KGSKIP=0) -C JBEG - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C (DEFAULTS TO 1 IF JBEG=0) -C (IF JBEG=0 AND IDIR<0, WAVE IS ZEROED BEFORE TRANSFORM) -C JEND - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C (DEFAULTS TO (JMAX+1)/2 IF JEND=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C WAVE - REAL (*) WAVE FIELDS IF IDIR>0 -C GRIDMN - REAL (KMAX) GLOBAL MEANS IF IDIR<0 -C GRIDXN - REAL (*) N.H. X-GRADIENTS (STARTING AT JBEG) IF IDIR<0 -C GRIDXS - REAL (*) S.H. X-GRADIENTS (STARTING AT JBEG) IF IDIR<0 -C GRIDYN - REAL (*) N.H. Y-GRADIENTS (STARTING AT JBEG) IF IDIR<0 -C GRIDYS - REAL (*) S.H. Y-GRADIENTS (STARTING AT JBEG) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (*) WAVE FIELDS IF IDIR<0 -C GRIDMN - REAL (KMAX) GLOBAL MEANS IF IDIR>0 -C GRIDXN - REAL (*) N.H. X-GRADIENTS (STARTING AT JBEG) IF IDIR>0 -C GRIDXS - REAL (*) S.H. X-GRADIENTS (STARTING AT JBEG) IF IDIR>0 -C [GRIDX=(D(WAVE)/DLAM)/(CLAT*RERTH)] -C GRIDYN - REAL (*) N.H. Y-GRADIENTS (STARTING AT JBEG) IF IDIR>0 -C GRIDYS - REAL (*) S.H. Y-GRADIENTS (STARTING AT JBEG) IF IDIR>0 -C [GRIDY=(D(WAVE)/DPHI)/RERTH] -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgpt. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPT TRANSFORM SPECTRAL SCALAR TO STATION POINTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C TO SPECIFIED SETS OF STATION POINTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND POINT FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER STATIONS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPT(IROMB,MAXWV,KMAX,NMAX, -C & KWSKIP,KGSKIP,NRSKIP,NGSKIP, -C & RLAT,RLON,WAVE,GP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C GP - REAL (*) STATION POINT SETS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgptv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPTV TRANSFORM SPECTRAL VECTOR TO STATION POINTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C TO SPECIFIED SETS OF STATION POINT VECTORS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND POINT FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER STATIONS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPTV(IROMB,MAXWV,KMAX,NMAX, -C & KWSKIP,KGSKIP,NRSKIP,NGSKIP, -C & RLAT,RLON,WAVED,WAVEZ,UP,VP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS -C OUTPUT ARGUMENTS: -C UP - REAL (*) STATION POINT U-WIND SETS -C VP - REAL (*) STATION POINT V-WIND SETS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgptd. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPTD TRANSFORM SPECTRAL TO STATION POINT GRADIENTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C TO SPECIFIED SETS OF STATION POINT GRADIENTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND POINT FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER STATIONS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPTD(IROMB,MAXWV,KMAX,NMAX, -C & KWSKIP,KGSKIP,NRSKIP,NGSKIP, -C & RLAT,RLON,WAVE,XP,YP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C XP - REAL (*) STATION POINT X-GRADIENT SETS -C YP - REAL (*) STATION POINT Y-GRADIENT SETS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTGPTV TRANSFORM SPECTRAL VECTOR TO STATION POINTS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgps. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPS TRANSFORM SPECTRAL SCALAR TO POLAR STEREO. -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C TO SCALAR FIELDS ON A PAIR OF POLAR STEREOGRAPHIC GRIDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TWO SQUARE POLAR STEREOGRAPHIC GRIDS ARE CENTERED -C ON THE RESPECTIVE POLES, WITH THE ORIENTATION LONGITUDE -C OF THE SOUTHERN HEMISPHERE GRID 180 DEGREES OPPOSITE -C THAT OF THE NORTHERN HEMISPHERE GRID. -C -C THE TRANSFORM IS MADE EFFICIENT \ 4 | 5 / -C BY COMBINING POINTS IN EIGHT SECTORS \ | / -C OF EACH POLAR STEREOGRAPHIC GRID, 3 \ | / 6 -C NUMBERED AS IN THE DIAGRAM AT RIGHT. \|/ -C THE POLE AND THE SECTOR BOUNDARIES ----+---- -C ARE TREATED SPECIALLY IN THE CODE. /|\ -C UNFORTUNATELY, THIS APPROACH INDUCES 2 / | \ 7 -C SOME HAIRY INDEXING AND CODE LOQUACITY, / | \ -C FOR WHICH THE DEVELOPER APOLOGIZES. / 1 | 8 \ -C -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPS(IROMB,MAXWV,KMAX,NPS, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & TRUE,XMESH,ORIENT,WAVE,GN,GS) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C GN - REAL (*) NORTHERN POLAR STEREOGRAPHIC FIELDS -C GS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC FIELDS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgpsv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPSV TRANSFORM SPECTRAL VECTOR TO POLAR STEREO. -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C TO VECTOR FIELDS ON A PAIR OF POLAR STEREOGRAPHIC GRIDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TWO SQUARE POLAR STEREOGRAPHIC GRIDS ARE CENTERED -C ON THE RESPECTIVE POLES, WITH THE ORIENTATION LONGITUDE -C OF THE SOUTHERN HEMISPHERE GRID 180 DEGREES OPPOSITE -C THAT OF THE NORTHERN HEMISPHERE GRID. -C THE VECTORS ARE AUTOMATICALLY ROTATED TO BE RESOLVED -C RELATIVE TO THE RESPECTIVE POLAR STEREOGRAPHIC GRIDS. -C -C THE TRANSFORM IS MADE EFFICIENT \ 4 | 5 / -C BY COMBINING POINTS IN EIGHT SECTORS \ | / -C OF EACH POLAR STEREOGRAPHIC GRID, 3 \ | / 6 -C NUMBERED AS IN THE DIAGRAM AT RIGHT. \|/ -C THE POLE AND THE SECTOR BOUNDARIES ----+---- -C ARE TREATED SPECIALLY IN THE CODE. /|\ -C UNFORTUNATELY, THIS APPROACH INDUCES 2 / | \ 7 -C SOME HAIRY INDEXING AND CODE LOQUACITY, / | \ -C FOR WHICH THE DEVELOPER APOLOGIZES. / 1 | 8 \ -C -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPSV(IROMB,MAXWV,KMAX,NPS, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & TRUE,XMESH,ORIENT,WAVED,WAVEZ,UN,VN,US,VS) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS -C OUTPUT ARGUMENTS: -C UN - REAL (*) NORTHERN POLAR STEREOGRAPHIC U-WINDS -C VN - REAL (*) NORTHERN POLAR STEREOGRAPHIC V-WINDS -C US - REAL (*) SOUTHERN POLAR STEREOGRAPHIC U-WINDS -C VS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC V-WINDS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgpsd. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPSD TRANSFORM SPECTRAL TO POLAR STEREO. GRADIENTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C TO GRADIENT FIELDS ON A PAIR OF POLAR STEREOGRAPHIC GRIDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TWO SQUARE POLAR STEREOGRAPHIC GRIDS ARE CENTERED -C ON THE RESPECTIVE POLES, WITH THE ORIENTATION LONGITUDE -C OF THE SOUTHERN HEMISPHERE GRID 180 DEGREES OPPOSITE -C THAT OF THE NORTHERN HEMISPHERE GRID. -C THE VECTORS ARE AUTOMATICALLY ROTATED TO BE RESOLVED -C RELATIVE TO THE RESPECTIVE POLAR STEREOGRAPHIC GRIDS. -C -C THE TRANSFORM IS MADE EFFICIENT \ 4 | 5 / -C BY COMBINING POINTS IN EIGHT SECTORS \ | / -C OF EACH POLAR STEREOGRAPHIC GRID, 3 \ | / 6 -C NUMBERED AS IN THE DIAGRAM AT RIGHT. \|/ -C THE POLE AND THE SECTOR BOUNDARIES ----+---- -C ARE TREATED SPECIALLY IN THE CODE. /|\ -C UNFORTUNATELY, THIS APPROACH INDUCES 2 / | \ 7 -C SOME HAIRY INDEXING AND CODE LOQUACITY, / | \ -C FOR WHICH THE DEVELOPER APOLOGIZES. / 1 | 8 \ -C -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPSD(IROMB,MAXWV,KMAX,NPS, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & TRUE,XMESH,ORIENT,WAVE,XP,YP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C XN - REAL (*) NORTHERN POLAR STEREOGRAPHIC X-GRADIENTS -C YN - REAL (*) NORTHERN POLAR STEREOGRAPHIC Y-GRADIENTS -C XS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC X-GRADIENTS -C YS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC Y-GRADIENTS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTGPSV TRANSFORM SPECTRAL VECTOR TO POLAR STEREO. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgpm. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPM TRANSFORM SPECTRAL SCALAR TO MERCATOR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C TO SCALAR FIELDS ON A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE MERCATOR GRID IS IDENTIFIED BY THE LOCATION -C OF ITS FIRST POINT AND BY ITS RESPECTIVE INCREMENTS. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPM(IROMB,MAXWV,KMAX,MI,MJ, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & RLAT1,RLON1,DLAT,DLON,WAVE,GM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO MI*MJ IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO MI IF NJSKIP=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C GM - REAL (*) MERCATOR FIELDS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgpmv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPMV TRANSFORM SPECTRAL VECTOR TO MERCATOR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C TO VECTOR FIELDS ON A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE MERCATOR GRID IS IDENTIFIED BY THE LOCATION -C OF ITS FIRST POINT AND BY ITS RESPECTIVE INCREMENTS. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPMV(IROMB,MAXWV,KMAX,MI,MJ, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & RLAT1,RLON1,DLAT,DLON,WAVED,WAVEZ,UM,VM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO MI*MJ IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO MI IF NJSKIP=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS -C OUTPUT ARGUMENTS: -C UM - REAL (*) MERCATOR U-WINDS -C VM - REAL (*) MERCATOR V-WINDS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for sptgpmd. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPMD TRANSFORM SPECTRAL TO MERCATOR GRADIENTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C TO GRADIENT FIELDS ON A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE MERCATOR GRID IS IDENTIFIED BY THE LOCATION -C OF ITS FIRST POINT AND BY ITS RESPECTIVE INCREMENTS. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTGPMD(IROMB,MAXWV,KMAX,MI,MJ, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & RLAT1,RLON1,DLAT,DLON,WAVE,XM,YM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO MI*MJ IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO MI IF NJSKIP=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C XM - REAL (*) MERCATOR X-GRADIENTS -C YM - REAL (*) MERCATOR Y-GRADIENTS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTGPMV TRANSFORM SPECTRAL VECTOR TO MERCATOR -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for spgget. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPGGET GET GRID-SPACE CONSTANTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM GETS GRID-SPACE CONSTANTS. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPGGET(IDRT,IMAX,JMAX,CLAT,SLAT,WLAT,TRIG,IFAX) -C INPUT ARGUMENTS: -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C OUTPUT ARGUMENTS: -C CLAT - REAL (JMAX) COSINES LATITUDE -C SLAT - REAL (JMAX) SINES LATITUDE -C WLAT - REAL (JMAX) GAUSSIAN WEIGHTS -C TRIG - REAL (2*IMAX) FFT TRIG VALUES -C IFAX - INTEGER (20) FFT FACTORS -C -C SUBPROGRAMS CALLED: -C SPLAT COMPUTE LATITUDE FUNCTIONS -C FFTFAX COMPUTE FFT CONSTANTS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for spwget. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPWGET GET WAVE-SPACE CONSTANTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM GETS WAVE-SPACE CONSTANTS. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C OUTPUT ARGUMENTS: -C EPS - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EPSTOP - REAL (MAXWV+1) -C ENN1 - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C ELONN1 - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EON - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EONTOP - REAL (MAXWV+1) -C -C SUBPROGRAMS CALLED: -C SPEPS COMPUTE UTILITY SPECTRAL FIELDS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for splat. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPLAT COMPUTE LATITUDE FUNCTIONS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-20 -C -C ABSTRACT: COMPUTES COSINES OF COLATITUDE AND GAUSSIAN WEIGHTS -C FOR ONE OF THE FOLLOWING SPECIFIC GLOBAL SETS OF LATITUDES. -C GAUSSIAN LATITUDES (IDRT=4) -C EQUALLY-SPACED LATITUDES INCLUDING POLES (IDRT=0) -C EQUALLY-SPACED LATITUDES EXCLUDING POLES (IDRT=256) -C THE GAUSSIAN LATITUDES ARE LOCATED AT THE ZEROES OF THE -C LEGENDRE POLYNOMIAL OF THE GIVEN ORDER. THESE LATITUDES -C ARE EFFICIENT FOR REVERSIBLE TRANSFORMS FROM SPECTRAL SPACE. -C (ABOUT TWICE AS MANY EQUALLY-SPACED LATITUDES ARE NEEDED.) -C THE WEIGHTS FOR THE EQUALLY-SPACED LATITUDES ARE BASED ON -C ELLSAESSER (JAM,1966). (NO WEIGHT IS GIVEN THE POLE POINT.) -C NOTE THAT WHEN ANALYZING GRID TO SPECTRAL IN LATITUDE PAIRS, -C IF AN EQUATOR POINT EXISTS, ITS WEIGHT SHOULD BE HALVED. -C -C PROGRAM HISTORY LOG: -C 96-02-20 IREDELL -C -C USAGE: CALL SPLAT(IDRT,JMAX,SLAT,WLAT) -C -C INPUT ARGUMENT LIST: -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C JMAX - INTEGER NUMBER OF LATITUDES. -C -C OUTPUT ARGUMENT LIST: -C SLAT - REAL (JMAX) SINES OF LATITUDE. -C WLAT - REAL (JMAX) GAUSSIAN WEIGHTS. -C -C SUBPROGRAMS CALLED: -C MINV SOLVES FULL MATRIX PROBLEM -C -C REMARKS: FORTRAN 90 EXTENSIONS ARE USED. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - -Docblock for speps. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPEPS COMPUTE UTILITY SPECTRAL FIELDS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES CONSTANT FIELDS INDEXED IN THE SPECTRAL DOMAIN -C IN "IBM ORDER" (ZONAL WAVENUMBER IS THE SLOWER INDEX). -C IF L IS THE ZONAL WAVENUMBER AND N IS THE TOTAL WAVENUMBER -C AND A IS THE EARTH RADIUS, THEN THE FIELDS RETURNED ARE: -C (1) NORMALIZING FACTOR EPSILON=SQRT((N**2-L**2)/(4*N**2-1)) -C (2) LAPLACIAN FACTOR N*(N+1)/A**2 -C (3) ZONAL DERIVATIVE/LAPLACIAN FACTOR L/(N*(N+1))*A -C (4) MERIDIONAL DERIVATIVE/LAPLACIAN FACTOR EPSILON/N*A -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPEPS(I,M,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C -C OUTPUT ARGUMENT LIST: -C EPS - REAL ((M+1)*((I+1)*M+2)/2) SQRT((N**2-L**2)/(4*N**2-1)) -C EPSTOP - REAL (M+1) SQRT((N**2-L**2)/(4*N**2-1)) OVER TOP -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C ELONN1 - REAL ((M+1)*((I+1)*M+2)/2) L/(N*(N+1))*A -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - -Docblock for splegend. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: EVALUATES THE ORTHONORMAL ASSOCIATED LEGENDRE POLYNOMIALS -C IN THE SPECTRAL DOMAIN AT A GIVEN LATITUDE. -C SUBPROGRAM SPLEGEND SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C AND EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) THEN -C THE FOLLOWING BOOTSTRAPPING FORMULAS ARE USED: -C PLN(0,0)=SQRT(0.5) -C PLN(L,L)=PLN(L-1,L-1)*CLAT*SQRT(FLOAT(2*L+1)/FLOAT(2*L)) -C PLN(L,N)=(SLAT*PLN(L,N-1)-EPS(L,N-1)*PLN(L,N-2))/EPS(L,N) -C SYNTHESIS AT THE POLE NEEDS ONLY TWO ZONAL WAVENUMBERS. -C SCALAR FIELDS ARE SYNTHESIZED WITH ZONAL WAVENUMBER 0 WHILE -C VECTOR FIELDS ARE SYNTHESIZED WITH ZONAL WAVENUMBER 1. -C (THUS POLAR VECTOR FIELDS ARE IMPLICITLY DIVIDED BY CLAT.) -C THE FOLLOWING BOOTSTRAPPING FORMULAS ARE USED AT THE POLE: -C PLN(0,0)=SQRT(0.5) -C PLN(1,1)=SQRT(0.75) -C PLN(L,N)=(PLN(L,N-1)-EPS(L,N-1)*PLN(L,N-2))/EPS(L,N) -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPLEGEND(I,M,SLAT,CLAT,EPS,EPSTOP,PLN,PLNTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C SLAT - REAL SINE OF LATITUDE -C CLAT - REAL COSINE OF LATITUDE -C EPS - REAL ((M+1)*((I+1)*M+2)/2) SQRT((N**2-L**2)/(4*N**2-1)) -C EPSTOP - REAL (M+1) SQRT((N**2-L**2)/(4*N**2-1)) OVER TOP -C -C OUTPUT ARGUMENT LIST: -C PLN - REAL ((M+1)*((I+1)*M+2)/2) LEGENDRE POLYNOMIAL -C PLNTOP - REAL (M+1) LEGENDRE POLYNOMIAL OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - -Docblock for spanaly. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPANALY ANALYZE SPECTRAL FROM FOURIER -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: ANALYZES SPECTRAL COEFFICIENTS FROM FOURIER COEFFICIENTS -C FOR A LATITUDE PAIR (NORTHERN AND SOUTHERN HEMISPHERES). -C VECTOR COMPONENTS ARE MULTIPLIED BY COSINE OF LATITUDE. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C 94-08-01 MARK IREDELL MOVED ZONAL WAVENUMBER LOOP INSIDE -C -C USAGE: CALL SPANALY(I,M,IM,IX,NC,NCTOP,KM,WGT,CLAT,PLN,PLNTOP,MP, -C & F,SPC,SPCTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C IM - INTEGER EVEN NUMBER OF FOURIER COEFFICIENTS -C IX - INTEGER DIMENSION OF FOURIER COEFFICIENTS (IX>=IM+2) -C NC - INTEGER DIMENSION OF SPECTRAL COEFFICIENTS -C (NC>=(M+1)*((I+1)*M+2)) -C NCTOP - INTEGER DIMENSION OF SPECTRAL COEFFICIENTS OVER TOP -C (NCTOP>=2*(M+1)) -C KM - INTEGER NUMBER OF FIELDS -C WGT - REAL GAUSSIAN WEIGHT -C CLAT - REAL COSINE OF LATITUDE -C PLN - REAL ((M+1)*((I+1)*M+2)/2) LEGENDRE POLYNOMIALS -C PLNTOP - REAL (M+1) LEGENDRE POLYNOMIAL OVER TOP -C MP - INTEGER (KM) IDENTIFIERS (0 FOR SCALAR, 1 FOR VECTOR) -C F - REAL (IX,2,KM) FOURIER COEFFICIENTS COMBINED -C SPC - REAL (NC,KM) SPECTRAL COEFFICIENTS -C SPCTOP - REAL (NCTOP,KM) SPECTRAL COEFFICIENTS OVER TOP -C -C OUTPUT ARGUMENT LIST: -C SPC - REAL (NC,KM) SPECTRAL COEFFICIENTS -C SPCTOP - REAL (NCTOP,KM) SPECTRAL COEFFICIENTS OVER TOP -C -C SUBPROGRAMS CALLED: -C SGERX1 CRAY LIBRARY MATRIX RANK 1 UPDATE -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - -Docblock for spsynth. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: SYNTHESIZES FOURIER COEFFICIENTS FROM SPECTRAL COEFFICIENTS -C FOR A LATITUDE PAIR (NORTHERN AND SOUTHERN HEMISPHERES). -C VECTOR COMPONENTS ARE DIVIDED BY COSINE OF LATITUDE. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPSYNTH(I,M,IM,IX,NC,NCTOP,KM,CLAT,PLN,PLNTOP,MP, -C & SPC,SPCTOP,F) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C IM - INTEGER EVEN NUMBER OF FOURIER COEFFICIENTS -C IX - INTEGER DIMENSION OF FOURIER COEFFICIENTS (IX>=IM+2) -C NC - INTEGER DIMENSION OF SPECTRAL COEFFICIENTS -C (NC>=(M+1)*((I+1)*M+2)) -C NCTOP - INTEGER DIMENSION OF SPECTRAL COEFFICIENTS OVER TOP -C (NCTOP>=2*(M+1)) -C KM - INTEGER NUMBER OF FIELDS -C CLAT - REAL COSINE OF LATITUDE -C PLN - REAL ((M+1)*((I+1)*M+2)/2) LEGENDRE POLYNOMIAL -C PLNTOP - REAL (M+1) LEGENDRE POLYNOMIAL OVER TOP -C SPC - REAL (NC,KM) SPECTRAL COEFFICIENTS -C SPCTOP - REAL (NCTOP,KM) SPECTRAL COEFFICIENTS OVER TOP -C MP - INTEGER (KM) IDENTIFIERS (0 FOR SCALAR, 1 FOR VECTOR) -C -C OUTPUT ARGUMENT LIST: -C F - REAL (IX,2,KM) FOURIER COEFFICIENTS FOR LATITUDE PAIR -C -C SUBPROGRAMS CALLED: -C SGEMVX1 CRAY LIBRARY MATRIX TIMES VECTOR -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - -Docblock for spdz2uv. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE WIND COMPONENTS FROM DIVERGENCE AND VORTICITY -C IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) AND A IS EARTH RADIUS, -C THEN THE ZONAL WIND COMPONENT U IS COMPUTED AS -C U(L,N)=-I*L/(N*(N+1))*A*D(L,N) -C +EPS(L,N+1)/(N+1)*A*Z(L,N+1)-EPS(L,N)/N*A*Z(L,N-1) -C AND THE MERIDIONAL WIND COMPONENT V IS COMPUTED AS -C V(L,N)=-I*L/(N*(N+1))*A*Z(L,N) -C -EPS(L,N+1)/(N+1)*A*D(L,N+1)+EPS(L,N)/N*A*D(L,N-1) -C WHERE D IS DIVERGENCE AND Z IS VORTICITY. -C U AND V ARE WEIGHTED BY THE COSINE OF LATITUDE. -C EXTRA TERMS ARE COMPUTED OVER TOP OF THE SPECTRAL DOMAIN. -C ADVANTAGE IS TAKEN OF THE FACT THAT EPS(L,L)=0 -C IN ORDER TO VECTORIZE OVER THE ENTIRE SPECTRAL DOMAIN. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPDZ2UV(I,M,ENN1,ELONN1,EON,EONTOP,D,Z,U,V,UTOP,VTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C ELONN1 - REAL ((M+1)*((I+1)*M+2)/2) L/(N*(N+1))*A -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C D - REAL ((M+1)*((I+1)*M+2)) DIVERGENCE -C Z - REAL ((M+1)*((I+1)*M+2)) VORTICITY -C -C OUTPUT ARGUMENT LIST: -C U - REAL ((M+1)*((I+1)*M+2)) ZONAL WIND (TIMES COSLAT) -C V - REAL ((M+1)*((I+1)*M+2)) MERID WIND (TIMES COSLAT) -C UTOP - REAL (2*(M+1)) ZONAL WIND (TIMES COSLAT) OVER TOP -C VTOP - REAL (2*(M+1)) MERID WIND (TIMES COSLAT) OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - -Docblock for spuv2dz. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPUV2DZ COMPUTE DIVERGENCE AND VORTICITY FROM WINDS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE DIVERGENCE AND VORTICITY FROM WIND COMPONENTS -C IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) AND A IS EARTH RADIUS, -C THEN THE DIVERGENCE D IS COMPUTED AS -C D(L,N)=I*L*A*U(L,N) -C +EPS(L,N+1)*N*A*V(L,N+1)-EPS(L,N)*(N+1)*A*V(L,N-1) -C AND THE VORTICITY Z IS COMPUTED AS -C Z(L,N)=I*L*A*V(L,N) -C -EPS(L,N+1)*N*A*U(L,N+1)+EPS(L,N)*(N+1)*A*U(L,N-1) -C WHERE U IS THE ZONAL WIND AND V IS THE MERIDIONAL WIND. -C U AND V ARE WEIGHTED BY THE SECANT OF LATITUDE. -C EXTRA TERMS ARE USED OVER TOP OF THE SPECTRAL DOMAIN. -C ADVANTAGE IS TAKEN OF THE FACT THAT EPS(L,L)=0 -C IN ORDER TO VECTORIZE OVER THE ENTIRE SPECTRAL DOMAIN. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPUV2DZ(I,M,ENN1,ELONN1,EON,EONTOP,U,V,UTOP,VTOP,D,Z) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C ELONN1 - REAL ((M+1)*((I+1)*M+2)/2) L/(N*(N+1))*A -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C U - REAL ((M+1)*((I+1)*M+2)) ZONAL WIND (OVER COSLAT) -C V - REAL ((M+1)*((I+1)*M+2)) MERID WIND (OVER COSLAT) -C UTOP - REAL (2*(M+1)) ZONAL WIND (OVER COSLAT) OVER TOP -C VTOP - REAL (2*(M+1)) MERID WIND (OVER COSLAT) OVER TOP -C -C OUTPUT ARGUMENT LIST: -C D - REAL ((M+1)*((I+1)*M+2)) DIVERGENCE -C Z - REAL ((M+1)*((I+1)*M+2)) VORTICITY -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - -Docblock for spgradq. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPGRADQ COMPUTE GRADIENT IN SPECTRAL SPACE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE HORIZONTAL VECTOR GRADIENT OF A SCALAR FIELD -C IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) AND A IS EARTH RADIUS, -C THEN THE ZONAL GRADIENT OF Q(L,N) IS SIMPLY I*L/A*Q(L,N) -C WHILE THE MERIDIONAL GRADIENT OF Q(L,N) IS COMPUTED AS -C EPS(L,N+1)*(N+2)/A*Q(L,N+1)-EPS(L,N+1)*(N-1)/A*Q(L,N-1). -C EXTRA TERMS ARE COMPUTED OVER TOP OF THE SPECTRAL DOMAIN. -C ADVANTAGE IS TAKEN OF THE FACT THAT EPS(L,L)=0 -C IN ORDER TO VECTORIZE OVER THE ENTIRE SPECTRAL DOMAIN. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPGRADQ(I,M,ENN1,ELONN1,EON,EONTOP,Q,QDX,QDY,QDYTOP) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C ELONN1 - REAL ((M+1)*((I+1)*M+2)/2) L/(N*(N+1))*A -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C Q - REAL ((M+1)*((I+1)*M+2)) SCALAR FIELD -C -C OUTPUT ARGUMENT LIST: -C QDX - REAL ((M+1)*((I+1)*M+2)) ZONAL GRADIENT (TIMES COSLAT) -C QDY - REAL ((M+1)*((I+1)*M+2)) MERID GRADIENT (TIMES COSLAT) -C QDYTOP - REAL (2*(M+1)) MERID GRADIENT (TIMES COSLAT) OVER TOP -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - -Docblock for splaplac. - -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE LAPLACIAN OR THE INVERSE LAPLACIAN -C OF A SCALAR FIELD IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C THE LAPLACIAN OF Q(L,N) IS SIMPLY -N*(N+1)/A**2*Q(L,N) -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPLAPLAC(I,M,ENN1,Q,QD2,IDIR) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C Q - IF IDIR > 0, REAL ((M+1)*((I+1)*M+2)) SCALAR FIELD -C QD2 - IF IDIR < 0, REAL ((M+1)*((I+1)*M+2)) LAPLACIAN -C IDIR - INTEGER FLAG -C IDIR > 0 TO TAKE LAPLACIAN -C IDIR < 0 TO TAKE INVERSE LAPLACIAN -C -C OUTPUT ARGUMENT LIST: -C Q - IF IDIR < 0, REAL ((M+1)*((I+1)*M+2)) SCALAR FIELD -C (Q(0,0) IS NOT COMPUTED) -C QD2 - IF IDIR > 0, REAL ((M+1)*((I+1)*M+2)) LAPLACIAN -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ diff --git a/external/sp/v2.0.2/src/sppad.f b/external/sp/v2.0.2/src/sppad.f deleted file mode 100644 index 8d7140d49..000000000 --- a/external/sp/v2.0.2/src/sppad.f +++ /dev/null @@ -1,49 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPPAD(I1,M1,Q1,I2,M2,Q2) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPPAD PAD OR TRUNCATE A SPECTRAL FIELD -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: PAD OR TRUNCATE A SPECTRAL FIELD -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPPAD(I1,M1,Q1,I2,M2,Q2) -C -C INPUT ARGUMENT LIST: -C I1 - INTEGER INPUT SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M1 - INTEGER INPUT SPECTRAL TRUNCATION -C Q1 - REAL ((M+1)*((I+1)*M+2)) INPUT FIELD -C I2 - INTEGER OUTPUT SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M2 - INTEGER OUTPUT SPECTRAL TRUNCATION -C -C OUTPUT ARGUMENT LIST: -C Q2 - REAL ((M+1)*((I+1)*M+2)) OUTPUT FIELD -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN -C -C$$$ - REAL Q1((M1+1)*((I1+1)*M1+2)) - REAL Q2((M2+1)*((I2+1)*M2+2)) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - DO L=0,M2 - DO N=L,I2*L+M2 - KS2=L*(2*M2+(I2-1)*(L-1))+2*N - IF(L.LE.M1.AND.N.LE.I1*L+M1) THEN - KS1=L*(2*M1+(I1-1)*(L-1))+2*N - Q2(KS2+1)=Q1(KS1+1) - Q2(KS2+2)=Q1(KS1+2) - ELSE - Q2(KS2+1)=0 - Q2(KS2+2)=0 - ENDIF - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/spsynth.f b/external/sp/v2.0.2/src/spsynth.f deleted file mode 100644 index 4f6c0f486..000000000 --- a/external/sp/v2.0.2/src/spsynth.f +++ /dev/null @@ -1,165 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPSYNTH(I,M,IM,IX,NC,NCTOP,KM,CLAT,PLN,PLNTOP,MP, - & SPC,SPCTOP,F) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: SYNTHESIZES FOURIER COEFFICIENTS FROM SPECTRAL COEFFICIENTS -C FOR A LATITUDE PAIR (NORTHERN AND SOUTHERN HEMISPHERES). -C VECTOR COMPONENTS ARE DIVIDED BY COSINE OF LATITUDE. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C 1998-12-18 MARK IREDELL INCLUDE SCALAR AND GRADIENT OPTION -C -C USAGE: CALL SPSYNTH(I,M,IM,IX,NC,NCTOP,KM,CLAT,PLN,PLNTOP,MP, -C & SPC,SPCTOP,F) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C IM - INTEGER EVEN NUMBER OF FOURIER COEFFICIENTS -C IX - INTEGER DIMENSION OF FOURIER COEFFICIENTS (IX>=IM+2) -C NC - INTEGER DIMENSION OF SPECTRAL COEFFICIENTS -C (NC>=(M+1)*((I+1)*M+2)) -C NCTOP - INTEGER DIMENSION OF SPECTRAL COEFFICIENTS OVER TOP -C (NCTOP>=2*(M+1)) -C KM - INTEGER NUMBER OF FIELDS -C CLAT - REAL COSINE OF LATITUDE -C PLN - REAL ((M+1)*((I+1)*M+2)/2) LEGENDRE POLYNOMIAL -C PLNTOP - REAL (M+1) LEGENDRE POLYNOMIAL OVER TOP -C SPC - REAL (NC,KM) SPECTRAL COEFFICIENTS -C SPCTOP - REAL (NCTOP,KM) SPECTRAL COEFFICIENTS OVER TOP -C MP - INTEGER (KM) IDENTIFIERS (0 FOR SCALAR, 1 FOR VECTOR, -C OR 10 FOR SCALAR AND GRADIENT) -C -C OUTPUT ARGUMENT LIST: -C F - REAL (IX,2,KM) FOURIER COEFFICIENTS FOR LATITUDE PAIR -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - REAL PLN((M+1)*((I+1)*M+2)/2),PLNTOP(M+1) - INTEGER MP(KM) - REAL SPC(NC,KM),SPCTOP(NCTOP,KM) - REAL F(IX,2,KM) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C ZERO OUT FOURIER COEFFICIENTS. - DO K=1,KM - DO L=0,IM/2 - F(2*L+1,1,K)=0. - F(2*L+2,1,K)=0. - F(2*L+1,2,K)=0. - F(2*L+2,2,K)=0. - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SYNTHESIS OVER POLE. -C INITIALIZE FOURIER COEFFICIENTS WITH TERMS OVER TOP OF THE SPECTRUM. -C INITIALIZE EVEN AND ODD POLYNOMIALS SEPARATELY. - IF(CLAT.EQ.0) THEN - LTOPE=MOD(M+1+I,2) -!C$OMP PARALLEL DO PRIVATE(LB,LE,L,KS,KP,N,F1R,F1I) - DO K=1,KM - LB=MP(K) - LE=MP(K) - IF(MP(K).EQ.10) THEN - LB=0 - LE=1 - ENDIF - L=LB - IF(L.EQ.1) THEN - IF(L.EQ.LTOPE) THEN - F(2*L+1,1,K)=PLNTOP(L+1)*SPCTOP(2*L+1,K) - F(2*L+2,1,K)=PLNTOP(L+1)*SPCTOP(2*L+2,K) - ELSE - F(2*L+1,2,K)=PLNTOP(L+1)*SPCTOP(2*L+1,K) - F(2*L+2,2,K)=PLNTOP(L+1)*SPCTOP(2*L+2,K) - ENDIF - ENDIF -C FOR EACH ZONAL WAVENUMBER, SYNTHESIZE TERMS OVER TOTAL WAVENUMBER. -C SYNTHESIZE EVEN AND ODD POLYNOMIALS SEPARATELY. - DO L=LB,LE - KS=L*(2*M+(I-1)*(L-1)) - KP=KS/2+1 - DO N=L,I*L+M,2 - F(2*L+1,1,K)=F(2*L+1,1,K)+PLN(KP+N)*SPC(KS+2*N+1,K) - F(2*L+2,1,K)=F(2*L+2,1,K)+PLN(KP+N)*SPC(KS+2*N+2,K) - ENDDO - DO N=L+1,I*L+M,2 - F(2*L+1,2,K)=F(2*L+1,2,K)+PLN(KP+N)*SPC(KS+2*N+1,K) - F(2*L+2,2,K)=F(2*L+2,2,K)+PLN(KP+N)*SPC(KS+2*N+2,K) - ENDDO -C SEPARATE FOURIER COEFFICIENTS FROM EACH HEMISPHERE. -C ODD POLYNOMIALS CONTRIBUTE NEGATIVELY TO THE SOUTHERN HEMISPHERE. - F1R=F(2*L+1,1,K) - F1I=F(2*L+2,1,K) - F(2*L+1,1,K)=F1R+F(2*L+1,2,K) - F(2*L+2,1,K)=F1I+F(2*L+2,2,K) - F(2*L+1,2,K)=F1R-F(2*L+1,2,K) - F(2*L+2,2,K)=F1I-F(2*L+2,2,K) - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SYNTHESIS OVER FINITE LATITUDE. -C INITIALIZE FOURIER COEFFICIENTS WITH TERMS OVER TOP OF THE SPECTRUM. -C INITIALIZE EVEN AND ODD POLYNOMIALS SEPARATELY. - ELSE - LX=MIN(M,IM/2) - LTOPE=MOD(M+1,2) - LTOPO=1-LTOPE - LE=1+I*LTOPE - LO=2-I*LTOPO -!C$OMP PARALLEL DO PRIVATE(L,KS,KP,N,F1R,F1I) - DO K=1,KM - IF(MP(K).EQ.1) THEN - DO L=LTOPE,LX,2 - F(2*L+1,LE,K)=PLNTOP(L+1)*SPCTOP(2*L+1,K) - F(2*L+2,LE,K)=PLNTOP(L+1)*SPCTOP(2*L+2,K) - ENDDO - DO L=LTOPO,LX,2 - F(2*L+1,LO,K)=PLNTOP(L+1)*SPCTOP(2*L+1,K) - F(2*L+2,LO,K)=PLNTOP(L+1)*SPCTOP(2*L+2,K) - ENDDO - ENDIF -C FOR EACH ZONAL WAVENUMBER, SYNTHESIZE TERMS OVER TOTAL WAVENUMBER. -C SYNTHESIZE EVEN AND ODD POLYNOMIALS SEPARATELY. - DO L=0,LX - KS=L*(2*M+(I-1)*(L-1)) - KP=KS/2+1 - DO N=L,I*L+M,2 - F(2*L+1,1,K)=F(2*L+1,1,K)+PLN(KP+N)*SPC(KS+2*N+1,K) - F(2*L+2,1,K)=F(2*L+2,1,K)+PLN(KP+N)*SPC(KS+2*N+2,K) - ENDDO - DO N=L+1,I*L+M,2 - F(2*L+1,2,K)=F(2*L+1,2,K)+PLN(KP+N)*SPC(KS+2*N+1,K) - F(2*L+2,2,K)=F(2*L+2,2,K)+PLN(KP+N)*SPC(KS+2*N+2,K) - ENDDO - ENDDO -C SEPARATE FOURIER COEFFICIENTS FROM EACH HEMISPHERE. -C ODD POLYNOMIALS CONTRIBUTE NEGATIVELY TO THE SOUTHERN HEMISPHERE. -C DIVIDE VECTOR COMPONENTS BY COSINE LATITUDE. - DO L=0,LX - F1R=F(2*L+1,1,K) - F1I=F(2*L+2,1,K) - F(2*L+1,1,K)=F1R+F(2*L+1,2,K) - F(2*L+2,1,K)=F1I+F(2*L+2,2,K) - F(2*L+1,2,K)=F1R-F(2*L+1,2,K) - F(2*L+2,2,K)=F1I-F(2*L+2,2,K) - ENDDO - IF(MP(K).EQ.1) THEN - DO L=0,LX - F(2*L+1,1,K)=F(2*L+1,1,K)/CLAT - F(2*L+2,1,K)=F(2*L+2,1,K)/CLAT - F(2*L+1,2,K)=F(2*L+1,2,K)/CLAT - F(2*L+2,2,K)=F(2*L+2,2,K)/CLAT - ENDDO - ENDIF - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptez.f b/external/sp/v2.0.2/src/sptez.f deleted file mode 100644 index 68f006c2d..000000000 --- a/external/sp/v2.0.2/src/sptez.f +++ /dev/null @@ -1,83 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTEZ(IROMB,MAXWV,IDRT,IMAX,JMAX,WAVE,GRID,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTEZ PERFORM A SIMPLE SCALAR SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF A SCALAR QUANTITY -C AND A FIELD ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER'. -C THE GRID FIELD IS INDEXED EAST TO WEST, THEN NORTH TO SOUTH. -C FOR MORE FLEXIBILITY AND EFFICIENCY, CALL SPTRAN. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTEZ(IROMB,MAXWV,IDRT,IMAX,JMAX,WAVE,GRID,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C WAVE - REAL (2*MX) WAVE FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C GRID - REAL (IMAX,JMAX) GRID FIELD (E->W,N->S) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (2*MX) WAVE FIELD IF IDIR<0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C GRID - REAL (IMAX,JMAX) GRID FIELD (E->W,N->S) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRANF PERFORM A SCALAR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE((MAXWV+1)*((IROMB+1)*MAXWV+2)) - REAL GRID(IMAX,JMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - IP=1 - IS=1 - JN=IMAX - JS=-JN - KW=2*MX - KG=IMAX*JMAX - JB=1 - JE=(JMAX+1)/2 - JC=NCPUS() -! print *, " EM: SPTEZ:::JJJJJJJJJJJJJJJJJJJCCCCCCCCCCC=" ,JC - IF(IDIR.LT.0) WAVE=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - CALL SPTRANF(IROMB,MAXWV,IDRT,IMAX,JMAX,1, - & IP,IS,JN,JS,KW,KG,JB,JE,JC, - & WAVE,GRID,GRID(1,JMAX),IDIR) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptezd.f b/external/sp/v2.0.2/src/sptezd.f deleted file mode 100644 index d2818bd84..000000000 --- a/external/sp/v2.0.2/src/sptezd.f +++ /dev/null @@ -1,75 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTEZD(IROMB,MAXWV,IDRT,IMAX,JMAX, - & WAVE,GRIDMN,GRIDX,GRIDY,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTEZD PERFORM A SIMPLE GRADIENT SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF A SCALAR FIELD -C AND ITS MEAN AND GRADIENT ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER'. -C THE GRID FIELS IS INDEXED EAST TO WEST, THEN NORTH TO SOUTH. -C FOR MORE FLEXIBILITY AND EFFICIENCY, CALL SPTRAN. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTEZD(IROMB,MAXWV,IDRT,IMAX,JMAX, -C & WAVE,GRIDMN,GRIDX,GRIDY,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C WAVE - REAL (*) WAVE FIELD IF IDIR>0 -C GRIDMN - REAL GLOBAL MEAN IF IDIR<0 -C GRIDX - REAL (IMAX,JMAX) GRID X-GRADIENTS (E->W,N->S) IF IDIR<0 -C GRIDY - REAL (IMAX,JMAX) GRID Y-GRADIENTS (E->W,N->S) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (*) WAVE FIELD IF IDIR<0 -C GRIDMN - REAL GLOBAL MEAN IF IDIR>0 -C GRIDX - REAL (IMAX,JMAX) GRID X-GRADIENTS (E->W,N->S) IF IDIR>0 -C GRIDY - REAL (IMAX,JMAX) GRID Y-GRADIENTS (E->W,N->S) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRAND PERFORM A GRADIENT SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE(*),GRIDX(IMAX,JMAX),GRIDY(IMAX,JMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - JC=NCPUS() - CALL SPTRAND(IROMB,MAXWV,IDRT,IMAX,JMAX,1, - & 0,0,0,0,0,0,0,0,JC, - & WAVE,GRIDMN, - & GRIDX,GRIDX(1,JMAX),GRIDY,GRIDY(1,JMAX),1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptezm.f b/external/sp/v2.0.2/src/sptezm.f deleted file mode 100644 index 5e78444aa..000000000 --- a/external/sp/v2.0.2/src/sptezm.f +++ /dev/null @@ -1,83 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTEZM(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX,WAVE,GRID,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTEZ PERFORM SIMPLE SCALAR SPHERICAL TRANSFORMS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS SPHERICAL TRANSFORMS -C BETWEEN SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C AND FIELDS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C WAVE FIELDS ARE IN SEQUENTIAL 'IBM ORDER'. -C GRID FIELDS ARE INDEXED EAST TO WEST, THEN NORTH TO SOUTH. -C FOR MORE FLEXIBILITY AND EFFICIENCY, CALL SPTRAN. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTEZM(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX,WAVE,GRID,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES -C JMAX - INTEGER NUMBER OF LATITUDES -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM -C WAVE - REAL (2*MX,KMAX) WAVE FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C GRID - REAL (IMAX,JMAX,KMAX) GRID FIELD (E->W,N->S) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (2*MX,KMAX) WAVE FIELD IF IDIR<0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C GRID - REAL (IMAX,JMAX,KMAX) GRID FIELD (E->W,N->S) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRANF PERFORM A SCALAR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE((MAXWV+1)*((IROMB+1)*MAXWV+2),KMAX) - REAL GRID(IMAX,JMAX,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - IP=1 - IS=1 - JN=IMAX - JS=-JN - KW=2*MX - KG=IMAX*JMAX - JB=1 - JE=(JMAX+1)/2 - JC=NCPUS() - IF(IDIR.LT.0) WAVE=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - CALL SPTRANF(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IP,IS,JN,JS,KW,KG,JB,JE,JC, - & WAVE,GRID,GRID(1,JMAX,1),IDIR) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptezmd.f b/external/sp/v2.0.2/src/sptezmd.f deleted file mode 100644 index 4c91cf419..000000000 --- a/external/sp/v2.0.2/src/sptezmd.f +++ /dev/null @@ -1,78 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTEZMD(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & WAVE,GRIDMN,GRIDX,GRIDY,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTEZMD PERFORM SIMPLE GRADIENT SPHERICAL TRANSFORMS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS SPHERICAL TRANSFORMS -C BETWEEN SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C AND THEIR MEANS AND GRADIENTS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE FIELDS ARE IN SEQUENTIAL 'IBM ORDER'. -C THE GRID FIELDS ARE INDEXED EAST TO WEST, THEN NORTH TO SOUTH. -C FOR MORE FLEXIBILITY AND EFFICIENCY, CALL SPTRAN. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTEZMD(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & WAVE,GRIDMN,GRIDX,GRIDY,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C WAVE - REAL (MX,KMAX) WAVE FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2) -C GRIDMN - REAL (KMAX) GLOBAL MEAN IF IDIR<0 -C GRIDX - REAL (IMAX,JMAX,KMAX) GRID X-GRADIENTS (E->W,N->S) IF IDIR<0 -C GRIDY - REAL (IMAX,JMAX,KMAX) GRID Y-GRADIENTS (E->W,N->S) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (MX,KMAX) WAVE FIELD IF IDIR<0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2) -C GRIDMN - REAL (KMAX) GLOBAL MEAN IF IDIR>0 -C GRIDX - REAL (IMAX,JMAX,KMAX) GRID X-GRADIENTS (E->W,N->S) IF IDIR>0 -C GRIDY - REAL (IMAX,JMAX,KMAX) GRID Y-GRADIENTS (E->W,N->S) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRAND PERFORM A GRADIENT SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE((MAXWV+1)*((IROMB+1)*MAXWV+2),KMAX) - REAL GRIDMN(KMAX),GRIDX(IMAX,JMAX,KMAX),GRIDY(IMAX,JMAX,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - JC=NCPUS() - CALL SPTRAND(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & 0,0,0,0,0,0,0,0,JC, - & WAVE,GRIDMN, - & GRIDX,GRIDX(1,JMAX,1),GRIDY,GRIDY(1,JMAX,1),IDIR) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptezmv.f b/external/sp/v2.0.2/src/sptezmv.f deleted file mode 100644 index b33bcaff2..000000000 --- a/external/sp/v2.0.2/src/sptezmv.f +++ /dev/null @@ -1,95 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTEZMV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & WAVED,WAVEZ,GRIDU,GRIDV,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTEZVM PERFORM SIMPLE VECTOR SPHERICAL TRANSFORMS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS SPHERICAL TRANSFORMS -C BETWEEN SPECTRAL COEFFICIENTS OF DIVERGENCE AND CURL -C AND VECTOR FIELDS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C WAVE FIELDS ARE IN SEQUENTIAL 'IBM ORDER'. -C GRID FIELDS ARE INDEXED EAST TO WEST, THEN NORTH TO SOUTH. -C FOR MORE FLEXIBILITY AND EFFICIENCY, CALL SPTRAN. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTEZMV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & WAVED,WAVEZ,GRIDU,GRIDV,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES -C JMAX - INTEGER NUMBER OF LATITUDES -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM -C WAVED - REAL (2*MX,KMAX) WAVE DIVERGENCE FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C WAVEZ - REAL (2*MX,KMAX) WAVE VORTICITY FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C GRIDU - REAL (IMAX,JMAX,KMAX) GRID U-WIND (E->W,N->S) IF IDIR<0 -C GRIDV - REAL (IMAX,JMAX,KMAX) GRID V-WIND (E->W,N->S) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVED - REAL (2*MX,KMAX) WAVE DIVERGENCE FIELD IF IDIR<0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C WAVEZ - REAL (2*MX,KMAX) WAVE VORTICITY FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C GRIDU - REAL (IMAX,JMAX,KMAX) GRID U-WIND (E->W,N->S) IF IDIR>0 -C GRIDV - REAL (IMAX,JMAX,KMAX) GRID V-WIND (E->W,N->S) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRANFV PERFORM A VECTOR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVED((MAXWV+1)*((IROMB+1)*MAXWV+2),KMAX) - REAL WAVEZ((MAXWV+1)*((IROMB+1)*MAXWV+2),KMAX) - REAL GRIDU(IMAX,JMAX,KMAX) - REAL GRIDV(IMAX,JMAX,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - IP=1 - IS=1 - JN=IMAX - JS=-JN - KW=2*MX - KG=IMAX*JMAX - JB=1 - JE=(JMAX+1)/2 - JC=NCPUS() - IF(IDIR.LT.0) WAVED=0 - IF(IDIR.LT.0) WAVEZ=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - CALL SPTRANFV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IP,IS,JN,JS,KW,KG,JB,JE,JC, - & WAVED,WAVEZ, - & GRIDU,GRIDU(1,JMAX,1),GRIDV,GRIDV(1,JMAX,1),IDIR) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptezv.f b/external/sp/v2.0.2/src/sptezv.f deleted file mode 100644 index 97fadcddf..000000000 --- a/external/sp/v2.0.2/src/sptezv.f +++ /dev/null @@ -1,94 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTEZV(IROMB,MAXWV,IDRT,IMAX,JMAX, - & WAVED,WAVEZ,GRIDU,GRIDV,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTEZV PERFORM A SIMPLE VECTOR SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF DIVERGENCE AND CURL -C AND A VECTOR FIELD ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER'. -C THE GRID FIELS IS INDEXED EAST TO WEST, THEN NORTH TO SOUTH. -C FOR MORE FLEXIBILITY AND EFFICIENCY, CALL SPTRAN. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTEZV(IROMB,MAXWV,IDRT,IMAX,JMAX, -C & WAVED,WAVEZ,GRIDU,GRIDV,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C WAVED - REAL (2*MX) WAVE DIVERGENCE FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C WAVEZ - REAL (2*MX) WAVE VORTICITY FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C GRIDU - REAL (IMAX,JMAX) GRID U-WIND (E->W,N->S) IF IDIR<0 -C GRIDV - REAL (IMAX,JMAX) GRID V-WIND (E->W,N->S) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVED - REAL (2*MX) WAVE DIVERGENCE FIELD IF IDIR<0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C WAVEZ - REAL (2*MX) WAVE VORTICITY FIELD IF IDIR>0 -C WHERE MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 -C GRIDU - REAL (IMAX,JMAX) GRID U-WIND (E->W,N->S) IF IDIR>0 -C GRIDV - REAL (IMAX,JMAX) GRID V-WIND (E->W,N->S) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRANFV PERFORM A VECTOR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVED((MAXWV+1)*((IROMB+1)*MAXWV+2)) - REAL WAVEZ((MAXWV+1)*((IROMB+1)*MAXWV+2)) - REAL GRIDU(IMAX,JMAX) - REAL GRIDV(IMAX,JMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - IP=1 - IS=1 - JN=IMAX - JS=-JN - KW=2*MX - KG=IMAX*JMAX - JB=1 - JE=(JMAX+1)/2 - JC=NCPUS() - IF(IDIR.LT.0) WAVED=0 - IF(IDIR.LT.0) WAVEZ=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - CALL SPTRANFV(IROMB,MAXWV,IDRT,IMAX,JMAX,1, - & IP,IS,JN,JS,KW,KG,JB,JE,JC, - & WAVED,WAVEZ, - & GRIDU,GRIDU(1,JMAX),GRIDV,GRIDV(1,JMAX),IDIR) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgpm.f b/external/sp/v2.0.2/src/sptgpm.f deleted file mode 100644 index c1ad5513a..000000000 --- a/external/sp/v2.0.2/src/sptgpm.f +++ /dev/null @@ -1,137 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPM(IROMB,MAXWV,KMAX,MI,MJ, - & KWSKIP,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WAVE,GM) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPM TRANSFORM SPECTRAL SCALAR TO MERCATOR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C TO SCALAR FIELDS ON A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE MERCATOR GRID IS IDENTIFIED BY THE LOCATION -C OF ITS FIRST POINT AND BY ITS RESPECTIVE INCREMENTS. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTGPM(IROMB,MAXWV,KMAX,MI,MJ, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & RLAT1,RLON1,DLAT,DLON,WAVE,GM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO MI*MJ IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO MI IF NJSKIP=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C GM - REAL (*) MERCATOR FIELDS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE(*),GM(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - INTEGER MP(KMAX) - REAL WTOP(2*(MAXWV+1),KMAX) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),PLNTOP(MAXWV+1) - REAL F(2*MAXWV+3,2,KMAX) - REAL CLAT(MJ),SLAT(MJ),CLON(MAXWV,MI),SLON(MAXWV,MI) - PARAMETER(RERTH=6.3712E6) - PARAMETER(PI=3.14159265358979,DPR=180./PI) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - IDIM=2*MAXWV+3 - KW=KWSKIP - KG=KGSKIP - NI=NISKIP - NJ=NJSKIP - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=MI*MJ - IF(NI.EQ.0) NI=1 - IF(NJ.EQ.0) NJ=MI - DO I=1,MI - RLON=MOD(RLON1+DLON*(I-1)+3600,360.) - DO L=1,MAXWV - CLON(L,I)=COS(L*RLON/DPR) - SLON(L,I)=SIN(L*RLON/DPR) - ENDDO - ENDDO - YE=1-LOG(TAN((RLAT1+90)/2/DPR))*DPR/DLAT - DO J=1,MJ - RLAT=ATAN(EXP(DLAT/DPR*(J-YE)))*2*DPR-90 - CLAT(J)=COS(RLAT/DPR) - SLAT(J)=SIN(RLAT/DPR) - ENDDO - MP=0 -C$OMP PARALLEL DO - DO K=1,KMAX - WTOP(1:2*MXTOP,K)=0 - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM TO GRID -C$OMP PARALLEL DO PRIVATE(PLN,PLNTOP,F,IJK) - DO J=1,MJ - CALL SPLEGEND(IROMB,MAXWV,SLAT(J),CLAT(J),EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,KW,2*MXTOP,KMAX, - & CLAT(J),PLN,PLNTOP,MP,WAVE,WTOP,F) - DO K=1,KMAX - DO I=1,MI - IJK=(I-1)*NI+(J-1)*NJ+(K-1)*KG+1 - GM(IJK)=F(1,1,K) - ENDDO - DO L=1,MAXWV - DO I=1,MI - IJK=(I-1)*NI+(J-1)*NJ+(K-1)*KG+1 - GM(IJK)=GM(IJK)+2.*(F(2*L+1,1,K)*CLON(L,I) - & -F(2*L+2,1,K)*SLON(L,I)) - ENDDO - ENDDO - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgpmd.f b/external/sp/v2.0.2/src/sptgpmd.f deleted file mode 100644 index e083ce485..000000000 --- a/external/sp/v2.0.2/src/sptgpmd.f +++ /dev/null @@ -1,96 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPMD(IROMB,MAXWV,KMAX,MI,MJ, - & KWSKIP,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WAVE,XM,YM) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPMD TRANSFORM SPECTRAL TO MERCATOR GRADIENTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C TO GRADIENT FIELDS ON A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE MERCATOR GRID IS IDENTIFIED BY THE LOCATION -C OF ITS FIRST POINT AND BY ITS RESPECTIVE INCREMENTS. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTGPMD(IROMB,MAXWV,KMAX,MI,MJ, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & RLAT1,RLON1,DLAT,DLON,WAVE,XM,YM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO MI*MJ IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO MI IF NJSKIP=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C XM - REAL (*) MERCATOR X-GRADIENTS -C YM - REAL (*) MERCATOR Y-GRADIENTS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTGPMV TRANSFORM SPECTRAL VECTOR TO MERCATOR -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE(*),XM(*),YM(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL WD((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL WZ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - KW=KWSKIP - IF(KW.EQ.0) KW=2*MX -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE GRADIENTS -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WAVE(KWS+1),WD(1,K),1) - WZ(1:2*MX,K)=0. - ENDDO - CALL SPTGPMV(IROMB,MAXWV,KMAX,MI,MJ,MDIM,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WD,WZ,XM,YM) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgpmv.f b/external/sp/v2.0.2/src/sptgpmv.f deleted file mode 100644 index 317ac6a3f..000000000 --- a/external/sp/v2.0.2/src/sptgpmv.f +++ /dev/null @@ -1,152 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPMV(IROMB,MAXWV,KMAX,MI,MJ, - & KWSKIP,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WAVED,WAVEZ,UM,VM) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPMV TRANSFORM SPECTRAL VECTOR TO MERCATOR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C TO VECTOR FIELDS ON A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE MERCATOR GRID IS IDENTIFIED BY THE LOCATION -C OF ITS FIRST POINT AND BY ITS RESPECTIVE INCREMENTS. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTGPMV(IROMB,MAXWV,KMAX,MI,MJ, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & RLAT1,RLON1,DLAT,DLON,WAVED,WAVEZ,UM,VM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO MI*MJ IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO MI IF NJSKIP=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS -C OUTPUT ARGUMENTS: -C UM - REAL (*) MERCATOR U-WINDS -C VM - REAL (*) MERCATOR V-WINDS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVED(*),WAVEZ(*),UM(*),VM(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - INTEGER MP(2*KMAX) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,2*KMAX) - REAL WTOP(2*(MAXWV+1),2*KMAX) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),PLNTOP(MAXWV+1) - REAL F(2*MAXWV+3,2,2*KMAX) - REAL CLAT(MJ),SLAT(MJ),CLON(MAXWV,MI),SLON(MAXWV,MI) - PARAMETER(RERTH=6.3712E6) - PARAMETER(PI=3.14159265358979,DPR=180./PI) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - MDIM=2*MX+1 - IDIM=2*MAXWV+3 - KW=KWSKIP - KG=KGSKIP - NI=NISKIP - NJ=NJSKIP - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=MI*MJ - IF(NI.EQ.0) NI=1 - IF(NJ.EQ.0) NJ=MI - DO I=1,MI - RLON=MOD(RLON1+DLON*(I-1)+3600,360.) - DO L=1,MAXWV - CLON(L,I)=COS(L*RLON/DPR) - SLON(L,I)=SIN(L*RLON/DPR) - ENDDO - ENDDO - YE=1-LOG(TAN((RLAT1+90)/2/DPR))*DPR/DLAT - DO J=1,MJ - RLAT=ATAN(EXP(DLAT/DPR*(J-YE)))*2*DPR-90 - CLAT(J)=COS(RLAT/DPR) - SLAT(J)=SIN(RLAT/DPR) - ENDDO - MP=1 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE SPECTRAL WINDS -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - CALL SPDZ2UV(IROMB,MAXWV,ENN1,ELONN1,EON,EONTOP, - & WAVED(KWS+1),WAVEZ(KWS+1), - & W(1,K),W(1,KMAX+K),WTOP(1,K),WTOP(1,KMAX+K)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM TO GRID -C$OMP PARALLEL DO PRIVATE(PLN,PLNTOP,F,KU,KV,IJK) - DO J=1,MJ - CALL SPLEGEND(IROMB,MAXWV,SLAT(J),CLAT(J),EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,MDIM,2*MXTOP,2*KMAX, - & CLAT(J),PLN,PLNTOP,MP,W,WTOP,F) - DO K=1,KMAX - KU=K - KV=K+KMAX - DO I=1,MI - IJK=(I-1)*NI+(J-1)*NJ+(K-1)*KG+1 - UM(IJK)=F(1,1,KU) - VM(IJK)=F(1,1,KV) - ENDDO - DO L=1,MAXWV - DO I=1,MI - IJK=(I-1)*NI+(J-1)*NJ+(K-1)*KG+1 - UM(IJK)=UM(IJK)+2.*(F(2*L+1,1,KU)*CLON(L,I) - & -F(2*L+2,1,KU)*SLON(L,I)) - VM(IJK)=VM(IJK)+2.*(F(2*L+1,1,KV)*CLON(L,I) - & -F(2*L+2,1,KV)*SLON(L,I)) - ENDDO - ENDDO - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgps.f b/external/sp/v2.0.2/src/sptgps.f deleted file mode 100644 index 867fc7114..000000000 --- a/external/sp/v2.0.2/src/sptgps.f +++ /dev/null @@ -1,540 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPS(IROMB,MAXWV,KMAX,NPS, - & KWSKIP,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WAVE,GN,GS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPS TRANSFORM SPECTRAL SCALAR TO POLAR STEREO. -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C TO SCALAR FIELDS ON A PAIR OF POLAR STEREOGRAPHIC GRIDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TWO SQUARE POLAR STEREOGRAPHIC GRIDS ARE CENTERED -C ON THE RESPECTIVE POLES, WITH THE ORIENTATION LONGITUDE -C OF THE SOUTHERN HEMISPHERE GRID 180 DEGREES OPPOSITE -C THAT OF THE NORTHERN HEMISPHERE GRID. -C -C THE TRANSFORM IS MADE EFFICIENT \ 4 | 5 / -C BY COMBINING POINTS IN EIGHT SECTORS \ | / -C OF EACH POLAR STEREOGRAPHIC GRID, 3 \ | / 6 -C NUMBERED AS IN THE DIAGRAM AT RIGHT. \|/ -C THE POLE AND THE SECTOR BOUNDARIES ----+---- -C ARE TREATED SPECIALLY IN THE CODE. /|\ -C UNFORTUNATELY, THIS APPROACH INDUCES 2 / | \ 7 -C SOME HAIRY INDEXING AND CODE LOQUACITY, / | \ -C FOR WHICH THE DEVELOPER APOLOGIZES. / 1 | 8 \ -C -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTGPS(IROMB,MAXWV,KMAX,NPS, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & TRUE,XMESH,ORIENT,WAVE,GN,GS) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C GN - REAL (*) NORTHERN POLAR STEREOGRAPHIC FIELDS -C GS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC FIELDS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE(*),GN(*),GS(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - INTEGER MP(KMAX) - REAL SLON(MAXWV,8),CLON(MAXWV,8),SROT(0:3),CROT(0:3) - REAL WTOP(2*(MAXWV+1),KMAX) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),PLNTOP(MAXWV+1) - REAL F(2*MAXWV+3,2,KMAX) - DATA SROT/0.,1.,0.,-1./,CROT/1.,0.,-1.,0./ - PARAMETER(RERTH=6.3712E6) - PARAMETER(PI=3.14159265358979,DPR=180./PI) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - IDIM=2*MAXWV+3 - KW=KWSKIP - KG=KGSKIP - NI=NISKIP - NJ=NJSKIP - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=NPS*NPS - IF(NI.EQ.0) NI=1 - IF(NJ.EQ.0) NJ=NPS - MP=0 - NPH=(NPS-1)/2 - GQ=((1.+SIN(TRUE/DPR))*RERTH/XMESH)**2 -C$OMP PARALLEL DO - DO K=1,KMAX - WTOP(1:2*MXTOP,K)=0 - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE POLE POINT - I1=NPH+1 - J1=NPH+1 - IJ1=(I1-1)*NI+(J1-1)*NJ+1 - SLAT1=1. - CLAT1=0. - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,KW,2*MXTOP,KMAX, - & CLAT1,PLN,PLNTOP,MP,WAVE,WTOP,F) -CDIR$ IVDEP - DO K=1,KMAX - IJK1=IJ1+(K-1)*KG - GN(IJK1)=F(1,1,K) - GS(IJK1)=F(1,2,K) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE POINTS ALONG THE ROW AND COLUMN OF THE POLE, -C STARTING AT THE ORIENTATION LONGITUDE AND GOING CLOCKWISE. -C$OMP PARALLEL DO PRIVATE(I1,J2,I2,J3,I3,J4,I4,J5,I5,J6,I6,J7,I7,J8,I8) -C$OMP& PRIVATE(IJ1,IJ2,IJ3,IJ4,IJ5,IJ6,IJ7,IJ8) -C$OMP& PRIVATE(IJK1,IJK2,IJK3,IJK4,IJK5,IJK6,IJK7,IJK8) -C$OMP& PRIVATE(DJ1,DI1,RQ,RADLON,RADLON1,RADLON2,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,SLON,CLON,LR,LI) - DO J1=1,NPH - I1=NPH+1 - RADLON=ORIENT/DPR - J3=NPS+1-I1 - I3=J1 - J5=NPS+1-J1 - I5=NPS+1-I1 - J7=I1 - I7=NPS+1-J1 - IJ1=(I1-1)*NI+(J1-1)*NJ+1 - IJ3=(I3-1)*NI+(J3-1)*NJ+1 - IJ5=(I5-1)*NI+(J5-1)*NJ+1 - IJ7=(I7-1)*NI+(J7-1)*NJ+1 - DI1=I1-NPH-1 - DJ1=J1-NPH-1 - RQ=DI1**2+DJ1**2 - SLAT1=(GQ-RQ)/(GQ+RQ) - CLAT1=SQRT(1.-SLAT1**2) - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,KW,2*MXTOP,KMAX, - & CLAT1,PLN,PLNTOP,MP,WAVE,WTOP,F) - DO L=1,MAXWV - SLON(L,1)=SIN(L*RADLON) - CLON(L,1)=COS(L*RADLON) - SLON(L,3)=SLON(L,1)*CROT(MOD(1*L,4)) - & -CLON(L,1)*SROT(MOD(1*L,4)) - CLON(L,3)=CLON(L,1)*CROT(MOD(1*L,4)) - & +SLON(L,1)*SROT(MOD(1*L,4)) - SLON(L,5)=SLON(L,1)*CROT(MOD(2*L,4)) - & -CLON(L,1)*SROT(MOD(2*L,4)) - CLON(L,5)=CLON(L,1)*CROT(MOD(2*L,4)) - & +SLON(L,1)*SROT(MOD(2*L,4)) - SLON(L,7)=SLON(L,1)*CROT(MOD(3*L,4)) - & -CLON(L,1)*SROT(MOD(3*L,4)) - CLON(L,7)=CLON(L,1)*CROT(MOD(3*L,4)) - & +SLON(L,1)*SROT(MOD(3*L,4)) - ENDDO -CDIR$ IVDEP - DO K=1,KMAX - IJK1=IJ1+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK7=IJ7+(K-1)*KG - GN(IJK1)=F(1,1,K) - GN(IJK3)=F(1,1,K) - GN(IJK5)=F(1,1,K) - GN(IJK7)=F(1,1,K) - GS(IJK1)=F(1,2,K) - GS(IJK3)=F(1,2,K) - GS(IJK5)=F(1,2,K) - GS(IJK7)=F(1,2,K) - ENDDO - IF(KMAX.EQ.1) THEN - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 - GN(IJ1)=GN(IJ1)+2*(F(LR,1,1)*CLON(L,1) - & -F(LI,1,1)*SLON(L,1)) - GN(IJ3)=GN(IJ3)+2*(F(LR,1,1)*CLON(L,3) - & -F(LI,1,1)*SLON(L,3)) - GN(IJ5)=GN(IJ5)+2*(F(LR,1,1)*CLON(L,5) - & -F(LI,1,1)*SLON(L,5)) - GN(IJ7)=GN(IJ7)+2*(F(LR,1,1)*CLON(L,7) - & -F(LI,1,1)*SLON(L,7)) - GS(IJ1)=GS(IJ1)+2*(F(LR,2,1)*CLON(L,5) - & -F(LI,2,1)*SLON(L,5)) - GS(IJ3)=GS(IJ3)+2*(F(LR,2,1)*CLON(L,3) - & -F(LI,2,1)*SLON(L,3)) - GS(IJ5)=GS(IJ5)+2*(F(LR,2,1)*CLON(L,1) - & -F(LI,2,1)*SLON(L,1)) - GS(IJ7)=GS(IJ7)+2*(F(LR,2,1)*CLON(L,7) - & -F(LI,2,1)*SLON(L,7)) - ENDDO - ELSE - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 -CDIR$ IVDEP - DO K=1,KMAX - IJK1=IJ1+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK7=IJ7+(K-1)*KG - GN(IJK1)=GN(IJK1)+2*(F(LR,1,K)*CLON(L,1) - & -F(LI,1,K)*SLON(L,1)) - GN(IJK3)=GN(IJK3)+2*(F(LR,1,K)*CLON(L,3) - & -F(LI,1,K)*SLON(L,3)) - GN(IJK5)=GN(IJK5)+2*(F(LR,1,K)*CLON(L,5) - & -F(LI,1,K)*SLON(L,5)) - GN(IJK7)=GN(IJK7)+2*(F(LR,1,K)*CLON(L,7) - & -F(LI,1,K)*SLON(L,7)) - GS(IJK1)=GS(IJK1)+2*(F(LR,2,K)*CLON(L,5) - & -F(LI,2,K)*SLON(L,5)) - GS(IJK3)=GS(IJK3)+2*(F(LR,2,K)*CLON(L,3) - & -F(LI,2,K)*SLON(L,3)) - GS(IJK5)=GS(IJK5)+2*(F(LR,2,K)*CLON(L,1) - & -F(LI,2,K)*SLON(L,1)) - GS(IJK7)=GS(IJK7)+2*(F(LR,2,K)*CLON(L,7) - & -F(LI,2,K)*SLON(L,7)) - ENDDO - ENDDO - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE POINTS ON THE MAIN DIAGONALS THROUGH THE POLE, -C STARTING CLOCKWISE OF THE ORIENTATION LONGITUDE AND GOING CLOCKWISE. -C$OMP PARALLEL DO PRIVATE(I1,J2,I2,J3,I3,J4,I4,J5,I5,J6,I6,J7,I7,J8,I8) -C$OMP& PRIVATE(IJ1,IJ2,IJ3,IJ4,IJ5,IJ6,IJ7,IJ8) -C$OMP& PRIVATE(IJK1,IJK2,IJK3,IJK4,IJK5,IJK6,IJK7,IJK8) -C$OMP& PRIVATE(DJ1,DI1,RQ,RADLON,RADLON1,RADLON2,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,SLON,CLON,LR,LI) - DO J1=1,NPH - I1=J1 - RADLON=(ORIENT-45)/DPR - J3=NPS+1-I1 - I3=J1 - J5=NPS+1-J1 - I5=NPS+1-I1 - J7=I1 - I7=NPS+1-J1 - IJ1=(I1-1)*NI+(J1-1)*NJ+1 - IJ3=(I3-1)*NI+(J3-1)*NJ+1 - IJ5=(I5-1)*NI+(J5-1)*NJ+1 - IJ7=(I7-1)*NI+(J7-1)*NJ+1 - DI1=I1-NPH-1 - DJ1=J1-NPH-1 - RQ=DI1**2+DJ1**2 - SLAT1=(GQ-RQ)/(GQ+RQ) - CLAT1=SQRT(1.-SLAT1**2) - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,KW,2*MXTOP,KMAX, - & CLAT1,PLN,PLNTOP,MP,WAVE,WTOP,F) - DO L=1,MAXWV - SLON(L,1)=SIN(L*RADLON) - CLON(L,1)=COS(L*RADLON) - SLON(L,3)=SLON(L,1)*CROT(MOD(1*L,4)) - & -CLON(L,1)*SROT(MOD(1*L,4)) - CLON(L,3)=CLON(L,1)*CROT(MOD(1*L,4)) - & +SLON(L,1)*SROT(MOD(1*L,4)) - SLON(L,5)=SLON(L,1)*CROT(MOD(2*L,4)) - & -CLON(L,1)*SROT(MOD(2*L,4)) - CLON(L,5)=CLON(L,1)*CROT(MOD(2*L,4)) - & +SLON(L,1)*SROT(MOD(2*L,4)) - SLON(L,7)=SLON(L,1)*CROT(MOD(3*L,4)) - & -CLON(L,1)*SROT(MOD(3*L,4)) - CLON(L,7)=CLON(L,1)*CROT(MOD(3*L,4)) - & +SLON(L,1)*SROT(MOD(3*L,4)) - ENDDO -CDIR$ IVDEP - DO K=1,KMAX - IJK1=IJ1+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK7=IJ7+(K-1)*KG - GN(IJK1)=F(1,1,K) - GN(IJK3)=F(1,1,K) - GN(IJK5)=F(1,1,K) - GN(IJK7)=F(1,1,K) - GS(IJK1)=F(1,2,K) - GS(IJK3)=F(1,2,K) - GS(IJK5)=F(1,2,K) - GS(IJK7)=F(1,2,K) - ENDDO - IF(KMAX.EQ.1) THEN - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 - GN(IJ1)=GN(IJ1)+2*(F(LR,1,1)*CLON(L,1) - & -F(LI,1,1)*SLON(L,1)) - GN(IJ3)=GN(IJ3)+2*(F(LR,1,1)*CLON(L,3) - & -F(LI,1,1)*SLON(L,3)) - GN(IJ5)=GN(IJ5)+2*(F(LR,1,1)*CLON(L,5) - & -F(LI,1,1)*SLON(L,5)) - GN(IJ7)=GN(IJ7)+2*(F(LR,1,1)*CLON(L,7) - & -F(LI,1,1)*SLON(L,7)) - GS(IJ1)=GS(IJ1)+2*(F(LR,2,1)*CLON(L,3) - & -F(LI,2,1)*SLON(L,3)) - GS(IJ3)=GS(IJ3)+2*(F(LR,2,1)*CLON(L,1) - & -F(LI,2,1)*SLON(L,1)) - GS(IJ5)=GS(IJ5)+2*(F(LR,2,1)*CLON(L,7) - & -F(LI,2,1)*SLON(L,7)) - GS(IJ7)=GS(IJ7)+2*(F(LR,2,1)*CLON(L,5) - & -F(LI,2,1)*SLON(L,5)) - ENDDO - ELSE - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 -CDIR$ IVDEP - DO K=1,KMAX - IJK1=IJ1+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK7=IJ7+(K-1)*KG - GN(IJK1)=GN(IJK1)+2*(F(LR,1,K)*CLON(L,1) - & -F(LI,1,K)*SLON(L,1)) - GN(IJK3)=GN(IJK3)+2*(F(LR,1,K)*CLON(L,3) - & -F(LI,1,K)*SLON(L,3)) - GN(IJK5)=GN(IJK5)+2*(F(LR,1,K)*CLON(L,5) - & -F(LI,1,K)*SLON(L,5)) - GN(IJK7)=GN(IJK7)+2*(F(LR,1,K)*CLON(L,7) - & -F(LI,1,K)*SLON(L,7)) - GS(IJK1)=GS(IJK1)+2*(F(LR,2,K)*CLON(L,3) - & -F(LI,2,K)*SLON(L,3)) - GS(IJK3)=GS(IJK3)+2*(F(LR,2,K)*CLON(L,1) - & -F(LI,2,K)*SLON(L,1)) - GS(IJK5)=GS(IJK5)+2*(F(LR,2,K)*CLON(L,7) - & -F(LI,2,K)*SLON(L,7)) - GS(IJK7)=GS(IJK7)+2*(F(LR,2,K)*CLON(L,5) - & -F(LI,2,K)*SLON(L,5)) - ENDDO - ENDDO - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE THE REMAINDER OF THE POLAR STEREOGRAPHIC DOMAIN, -C STARTING AT THE SECTOR JUST CLOCKWISE OF THE ORIENTATION LONGITUDE -C AND GOING CLOCKWISE UNTIL ALL EIGHT SECTORS ARE DONE. -C$OMP PARALLEL DO PRIVATE(I1,J2,I2,J3,I3,J4,I4,J5,I5,J6,I6,J7,I7,J8,I8) -C$OMP& PRIVATE(IJ1,IJ2,IJ3,IJ4,IJ5,IJ6,IJ7,IJ8) -C$OMP& PRIVATE(IJK1,IJK2,IJK3,IJK4,IJK5,IJK6,IJK7,IJK8) -C$OMP& PRIVATE(DJ1,DI1,RQ,RADLON,RADLON1,RADLON2,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,SLON,CLON,LR,LI) - DO J1=1,NPH-1 - DO I1=J1+1,NPH - J2=I1 - I2=J1 - J3=NPS+1-I1 - I3=J1 - J4=NPS+1-J1 - I4=I1 - J5=NPS+1-J1 - I5=NPS+1-I1 - J6=NPS+1-I1 - I6=NPS+1-J1 - J7=I1 - I7=NPS+1-J1 - J8=J1 - I8=NPS+1-I1 - IJ1=(I1-1)*NI+(J1-1)*NJ+1 - IJ2=(I2-1)*NI+(J2-1)*NJ+1 - IJ3=(I3-1)*NI+(J3-1)*NJ+1 - IJ4=(I4-1)*NI+(J4-1)*NJ+1 - IJ5=(I5-1)*NI+(J5-1)*NJ+1 - IJ6=(I6-1)*NI+(J6-1)*NJ+1 - IJ7=(I7-1)*NI+(J7-1)*NJ+1 - IJ8=(I8-1)*NI+(J8-1)*NJ+1 - DI1=I1-NPH-1 - DJ1=J1-NPH-1 - RQ=DI1**2+DJ1**2 - SLAT1=(GQ-RQ)/(GQ+RQ) - CLAT1=SQRT(1.-SLAT1**2) - RADLON1=ORIENT/DPR+ATAN(-DI1/DJ1) - RADLON2=(ORIENT-45)/DPR*2-RADLON1 - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,KW,2*MXTOP,KMAX, - & CLAT1,PLN,PLNTOP,MP,WAVE,WTOP,F) - DO L=1,MAXWV - SLON(L,1)=SIN(L*RADLON1) - CLON(L,1)=COS(L*RADLON1) - SLON(L,2)=SIN(L*RADLON2) - CLON(L,2)=COS(L*RADLON2) - SLON(L,3)=SLON(L,1)*CROT(MOD(1*L,4)) - & -CLON(L,1)*SROT(MOD(1*L,4)) - CLON(L,3)=CLON(L,1)*CROT(MOD(1*L,4)) - & +SLON(L,1)*SROT(MOD(1*L,4)) - SLON(L,4)=SLON(L,2)*CROT(MOD(1*L,4)) - & -CLON(L,2)*SROT(MOD(1*L,4)) - CLON(L,4)=CLON(L,2)*CROT(MOD(1*L,4)) - & +SLON(L,2)*SROT(MOD(1*L,4)) - SLON(L,5)=SLON(L,1)*CROT(MOD(2*L,4)) - & -CLON(L,1)*SROT(MOD(2*L,4)) - CLON(L,5)=CLON(L,1)*CROT(MOD(2*L,4)) - & +SLON(L,1)*SROT(MOD(2*L,4)) - SLON(L,6)=SLON(L,2)*CROT(MOD(2*L,4)) - & -CLON(L,2)*SROT(MOD(2*L,4)) - CLON(L,6)=CLON(L,2)*CROT(MOD(2*L,4)) - & +SLON(L,2)*SROT(MOD(2*L,4)) - SLON(L,7)=SLON(L,1)*CROT(MOD(3*L,4)) - & -CLON(L,1)*SROT(MOD(3*L,4)) - CLON(L,7)=CLON(L,1)*CROT(MOD(3*L,4)) - & +SLON(L,1)*SROT(MOD(3*L,4)) - SLON(L,8)=SLON(L,2)*CROT(MOD(3*L,4)) - & -CLON(L,2)*SROT(MOD(3*L,4)) - CLON(L,8)=CLON(L,2)*CROT(MOD(3*L,4)) - & +SLON(L,2)*SROT(MOD(3*L,4)) - ENDDO -CDIR$ IVDEP - DO K=1,KMAX - IJK1=IJ1+(K-1)*KG - IJK2=IJ2+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK4=IJ4+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK6=IJ6+(K-1)*KG - IJK7=IJ7+(K-1)*KG - IJK8=IJ8+(K-1)*KG - GN(IJK1)=F(1,1,K) - GN(IJK2)=F(1,1,K) - GN(IJK3)=F(1,1,K) - GN(IJK4)=F(1,1,K) - GN(IJK5)=F(1,1,K) - GN(IJK6)=F(1,1,K) - GN(IJK7)=F(1,1,K) - GN(IJK8)=F(1,1,K) - GS(IJK1)=F(1,2,K) - GS(IJK2)=F(1,2,K) - GS(IJK3)=F(1,2,K) - GS(IJK4)=F(1,2,K) - GS(IJK5)=F(1,2,K) - GS(IJK6)=F(1,2,K) - GS(IJK7)=F(1,2,K) - GS(IJK8)=F(1,2,K) - ENDDO - IF(KMAX.EQ.1) THEN - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 - GN(IJ1)=GN(IJ1)+2*(F(LR,1,1)*CLON(L,1) - & -F(LI,1,1)*SLON(L,1)) - GN(IJ2)=GN(IJ2)+2*(F(LR,1,1)*CLON(L,2) - & -F(LI,1,1)*SLON(L,2)) - GN(IJ3)=GN(IJ3)+2*(F(LR,1,1)*CLON(L,3) - & -F(LI,1,1)*SLON(L,3)) - GN(IJ4)=GN(IJ4)+2*(F(LR,1,1)*CLON(L,4) - & -F(LI,1,1)*SLON(L,4)) - GN(IJ5)=GN(IJ5)+2*(F(LR,1,1)*CLON(L,5) - & -F(LI,1,1)*SLON(L,5)) - GN(IJ6)=GN(IJ6)+2*(F(LR,1,1)*CLON(L,6) - & -F(LI,1,1)*SLON(L,6)) - GN(IJ7)=GN(IJ7)+2*(F(LR,1,1)*CLON(L,7) - & -F(LI,1,1)*SLON(L,7)) - GN(IJ8)=GN(IJ8)+2*(F(LR,1,1)*CLON(L,8) - & -F(LI,1,1)*SLON(L,8)) - GS(IJ1)=GS(IJ1)+2*(F(LR,2,1)*CLON(L,4) - & -F(LI,2,1)*SLON(L,4)) - GS(IJ2)=GS(IJ2)+2*(F(LR,2,1)*CLON(L,3) - & -F(LI,2,1)*SLON(L,3)) - GS(IJ3)=GS(IJ3)+2*(F(LR,2,1)*CLON(L,2) - & -F(LI,2,1)*SLON(L,2)) - GS(IJ4)=GS(IJ4)+2*(F(LR,2,1)*CLON(L,1) - & -F(LI,2,1)*SLON(L,1)) - GS(IJ5)=GS(IJ5)+2*(F(LR,2,1)*CLON(L,8) - & -F(LI,2,1)*SLON(L,8)) - GS(IJ6)=GS(IJ6)+2*(F(LR,2,1)*CLON(L,7) - & -F(LI,2,1)*SLON(L,7)) - GS(IJ7)=GS(IJ7)+2*(F(LR,2,1)*CLON(L,6) - & -F(LI,2,1)*SLON(L,6)) - GS(IJ8)=GS(IJ8)+2*(F(LR,2,1)*CLON(L,5) - & -F(LI,2,1)*SLON(L,5)) - ENDDO - ELSE - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 -CDIR$ IVDEP - DO K=1,KMAX - IJK1=IJ1+(K-1)*KG - IJK2=IJ2+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK4=IJ4+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK6=IJ6+(K-1)*KG - IJK7=IJ7+(K-1)*KG - IJK8=IJ8+(K-1)*KG - GN(IJK1)=GN(IJK1)+2*(F(LR,1,K)*CLON(L,1) - & -F(LI,1,K)*SLON(L,1)) - GN(IJK2)=GN(IJK2)+2*(F(LR,1,K)*CLON(L,2) - & -F(LI,1,K)*SLON(L,2)) - GN(IJK3)=GN(IJK3)+2*(F(LR,1,K)*CLON(L,3) - & -F(LI,1,K)*SLON(L,3)) - GN(IJK4)=GN(IJK4)+2*(F(LR,1,K)*CLON(L,4) - & -F(LI,1,K)*SLON(L,4)) - GN(IJK5)=GN(IJK5)+2*(F(LR,1,K)*CLON(L,5) - & -F(LI,1,K)*SLON(L,5)) - GN(IJK6)=GN(IJK6)+2*(F(LR,1,K)*CLON(L,6) - & -F(LI,1,K)*SLON(L,6)) - GN(IJK7)=GN(IJK7)+2*(F(LR,1,K)*CLON(L,7) - & -F(LI,1,K)*SLON(L,7)) - GN(IJK8)=GN(IJK8)+2*(F(LR,1,K)*CLON(L,8) - & -F(LI,1,K)*SLON(L,8)) - GS(IJK1)=GS(IJK1)+2*(F(LR,2,K)*CLON(L,4) - & -F(LI,2,K)*SLON(L,4)) - GS(IJK2)=GS(IJK2)+2*(F(LR,2,K)*CLON(L,3) - & -F(LI,2,K)*SLON(L,3)) - GS(IJK3)=GS(IJK3)+2*(F(LR,2,K)*CLON(L,2) - & -F(LI,2,K)*SLON(L,2)) - GS(IJK4)=GS(IJK4)+2*(F(LR,2,K)*CLON(L,1) - & -F(LI,2,K)*SLON(L,1)) - GS(IJK5)=GS(IJK5)+2*(F(LR,2,K)*CLON(L,8) - & -F(LI,2,K)*SLON(L,8)) - GS(IJK6)=GS(IJK6)+2*(F(LR,2,K)*CLON(L,7) - & -F(LI,2,K)*SLON(L,7)) - GS(IJK7)=GS(IJK7)+2*(F(LR,2,K)*CLON(L,6) - & -F(LI,2,K)*SLON(L,6)) - GS(IJK8)=GS(IJK8)+2*(F(LR,2,K)*CLON(L,5) - & -F(LI,2,K)*SLON(L,5)) - ENDDO - ENDDO - ENDIF - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgpsd.f b/external/sp/v2.0.2/src/sptgpsd.f deleted file mode 100644 index 25a9eccc7..000000000 --- a/external/sp/v2.0.2/src/sptgpsd.f +++ /dev/null @@ -1,104 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPSD(IROMB,MAXWV,KMAX,NPS, - & KWSKIP,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WAVE,XN,YN,XS,YS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPSD TRANSFORM SPECTRAL TO POLAR STEREO. GRADIENTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C TO GRADIENT FIELDS ON A PAIR OF POLAR STEREOGRAPHIC GRIDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TWO SQUARE POLAR STEREOGRAPHIC GRIDS ARE CENTERED -C ON THE RESPECTIVE POLES, WITH THE ORIENTATION LONGITUDE -C OF THE SOUTHERN HEMISPHERE GRID 180 DEGREES OPPOSITE -C THAT OF THE NORTHERN HEMISPHERE GRID. -C THE VECTORS ARE AUTOMATICALLY ROTATED TO BE RESOLVED -C RELATIVE TO THE RESPECTIVE POLAR STEREOGRAPHIC GRIDS. -C -C THE TRANSFORM IS MADE EFFICIENT \ 4 | 5 / -C BY COMBINING POINTS IN EIGHT SECTORS \ | / -C OF EACH POLAR STEREOGRAPHIC GRID, 3 \ | / 6 -C NUMBERED AS IN THE DIAGRAM AT RIGHT. \|/ -C THE POLE AND THE SECTOR BOUNDARIES ----+---- -C ARE TREATED SPECIALLY IN THE CODE. /|\ -C UNFORTUNATELY, THIS APPROACH INDUCES 2 / | \ 7 -C SOME HAIRY INDEXING AND CODE LOQUACITY, / | \ -C FOR WHICH THE DEVELOPER APOLOGIZES. / 1 | 8 \ -C -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTGPSD(IROMB,MAXWV,KMAX,NPS, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & TRUE,XMESH,ORIENT,WAVE,XP,YP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C XN - REAL (*) NORTHERN POLAR STEREOGRAPHIC X-GRADIENTS -C YN - REAL (*) NORTHERN POLAR STEREOGRAPHIC Y-GRADIENTS -C XS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC X-GRADIENTS -C YS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC Y-GRADIENTS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTGPSV TRANSFORM SPECTRAL VECTOR TO POLAR STEREO. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE(*),XN(*),YN(*),XS(*),YS(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL WD((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL WZ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - KW=KWSKIP - IF(KW.EQ.0) KW=2*MX -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE GRADIENTS -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WAVE(KWS+1),WD(1,K),1) - WZ(1:2*MX,K)=0. - ENDDO - CALL SPTGPSV(IROMB,MAXWV,KMAX,NPS,MDIM,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WD,WZ,XN,YN,XS,YS) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgpsv.f b/external/sp/v2.0.2/src/sptgpsv.f deleted file mode 100644 index 0ac116014..000000000 --- a/external/sp/v2.0.2/src/sptgpsv.f +++ /dev/null @@ -1,931 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPSV(IROMB,MAXWV,KMAX,NPS, - & KWSKIP,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WAVED,WAVEZ,UN,VN,US,VS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPSV TRANSFORM SPECTRAL VECTOR TO POLAR STEREO. -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C TO VECTOR FIELDS ON A PAIR OF POLAR STEREOGRAPHIC GRIDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TWO SQUARE POLAR STEREOGRAPHIC GRIDS ARE CENTERED -C ON THE RESPECTIVE POLES, WITH THE ORIENTATION LONGITUDE -C OF THE SOUTHERN HEMISPHERE GRID 180 DEGREES OPPOSITE -C THAT OF THE NORTHERN HEMISPHERE GRID. -C THE VECTORS ARE AUTOMATICALLY ROTATED TO BE RESOLVED -C RELATIVE TO THE RESPECTIVE POLAR STEREOGRAPHIC GRIDS. -C -C THE TRANSFORM IS MADE EFFICIENT \ 4 | 5 / -C BY COMBINING POINTS IN EIGHT SECTORS \ | / -C OF EACH POLAR STEREOGRAPHIC GRID, 3 \ | / 6 -C NUMBERED AS IN THE DIAGRAM AT RIGHT. \|/ -C THE POLE AND THE SECTOR BOUNDARIES ----+---- -C ARE TREATED SPECIALLY IN THE CODE. /|\ -C UNFORTUNATELY, THIS APPROACH INDUCES 2 / | \ 7 -C SOME HAIRY INDEXING AND CODE LOQUACITY, / | \ -C FOR WHICH THE DEVELOPER APOLOGIZES. / 1 | 8 \ -C -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER SECTOR POINTS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTGPSV(IROMB,MAXWV,KMAX,NPS, -C & KWSKIP,KGSKIP,NISKIP,NJSKIP, -C & TRUE,XMESH,ORIENT,WAVED,WAVEZ,UN,VN,US,VS) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS -C OUTPUT ARGUMENTS: -C UN - REAL (*) NORTHERN POLAR STEREOGRAPHIC U-WINDS -C VN - REAL (*) NORTHERN POLAR STEREOGRAPHIC V-WINDS -C US - REAL (*) SOUTHERN POLAR STEREOGRAPHIC U-WINDS -C VS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC V-WINDS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVED(*),WAVEZ(*),UN(*),VN(*),US(*),VS(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - INTEGER MP(2*KMAX) - REAL SLON(MAXWV,8),CLON(MAXWV,8),SROT(0:3),CROT(0:3) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,2*KMAX) - REAL WTOP(2*(MAXWV+1),2*KMAX) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),PLNTOP(MAXWV+1) - REAL F(2*MAXWV+3,2,2*KMAX) - DATA SROT/0.,1.,0.,-1./,CROT/1.,0.,-1.,0./ - PARAMETER(RERTH=6.3712E6) - PARAMETER(PI=3.14159265358979,DPR=180./PI) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - MDIM=2*MX+1 - IDIM=2*MAXWV+3 - KW=KWSKIP - KG=KGSKIP - NI=NISKIP - NJ=NJSKIP - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=NPS*NPS - IF(NI.EQ.0) NI=1 - IF(NJ.EQ.0) NJ=NPS - MP=1 - NPH=(NPS-1)/2 - GQ=((1.+SIN(TRUE/DPR))*RERTH/XMESH)**2 - SRH=SQRT(0.5) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE SPECTRAL WINDS -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - CALL SPDZ2UV(IROMB,MAXWV,ENN1,ELONN1,EON,EONTOP, - & WAVED(KWS+1),WAVEZ(KWS+1), - & W(1,K),W(1,KMAX+K),WTOP(1,K),WTOP(1,KMAX+K)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE POLE POINT - I1=NPH+1 - J1=NPH+1 - IJ1=(I1-1)*NI+(J1-1)*NJ+1 - SLAT1=1. - CLAT1=0. - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,MDIM,2*MXTOP,2*KMAX, - & CLAT1,PLN,PLNTOP,MP,W,WTOP,F) - COSO=COS(ORIENT/DPR) - SINO=SIN(ORIENT/DPR) -CDIR$ IVDEP - DO K=1,KMAX - KU=K - KV=K+KMAX - IJK1=IJ1+(K-1)*KG - UN(IJK1)=2*( COSO*F(3,1,KU)+SINO*F(3,1,KV)) - VN(IJK1)=2*(-SINO*F(3,1,KU)+COSO*F(3,1,KV)) - US(IJK1)=2*( COSO*F(3,2,KU)-SINO*F(3,2,KV)) - VS(IJK1)=2*( SINO*F(3,2,KU)+COSO*F(3,2,KV)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE POINTS ALONG THE ROW AND COLUMN OF THE POLE, -C STARTING AT THE ORIENTATION LONGITUDE AND GOING CLOCKWISE. -C$OMP PARALLEL DO PRIVATE(I1,J2,I2,J3,I3,J4,I4,J5,I5,J6,I6,J7,I7,J8,I8) -C$OMP& PRIVATE(IJ1,IJ2,IJ3,IJ4,IJ5,IJ6,IJ7,IJ8) -C$OMP& PRIVATE(IJK1,IJK2,IJK3,IJK4,IJK5,IJK6,IJK7,IJK8) -C$OMP& PRIVATE(DJ1,DI1,RQ,RR,RADLON,RADLON1,RADLON2,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,SLON,CLON,KU,KV,LR,LI) - DO J1=1,NPH - I1=NPH+1 - RADLON=ORIENT/DPR - J3=NPS+1-I1 - I3=J1 - J5=NPS+1-J1 - I5=NPS+1-I1 - J7=I1 - I7=NPS+1-J1 - IJ1=(I1-1)*NI+(J1-1)*NJ+1 - IJ3=(I3-1)*NI+(J3-1)*NJ+1 - IJ5=(I5-1)*NI+(J5-1)*NJ+1 - IJ7=(I7-1)*NI+(J7-1)*NJ+1 - DI1=I1-NPH-1 - DJ1=J1-NPH-1 - RQ=DI1**2+DJ1**2 - SLAT1=(GQ-RQ)/(GQ+RQ) - CLAT1=SQRT(1.-SLAT1**2) - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,MDIM,2*MXTOP,2*KMAX, - & CLAT1,PLN,PLNTOP,MP,W,WTOP,F) - DO L=1,MAXWV - SLON(L,1)=SIN(L*RADLON) - CLON(L,1)=COS(L*RADLON) - SLON(L,3)=SLON(L,1)*CROT(MOD(1*L,4)) - & -CLON(L,1)*SROT(MOD(1*L,4)) - CLON(L,3)=CLON(L,1)*CROT(MOD(1*L,4)) - & +SLON(L,1)*SROT(MOD(1*L,4)) - SLON(L,5)=SLON(L,1)*CROT(MOD(2*L,4)) - & -CLON(L,1)*SROT(MOD(2*L,4)) - CLON(L,5)=CLON(L,1)*CROT(MOD(2*L,4)) - & +SLON(L,1)*SROT(MOD(2*L,4)) - SLON(L,7)=SLON(L,1)*CROT(MOD(3*L,4)) - & -CLON(L,1)*SROT(MOD(3*L,4)) - CLON(L,7)=CLON(L,1)*CROT(MOD(3*L,4)) - & +SLON(L,1)*SROT(MOD(3*L,4)) - ENDDO -CDIR$ IVDEP - DO K=1,KMAX - KU=K - KV=K+KMAX - IJK1=IJ1+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK7=IJ7+(K-1)*KG - UN(IJK1)= F(1,1,KU) - VN(IJK1)= F(1,1,KV) - UN(IJK3)= F(1,1,KV) - VN(IJK3)=-F(1,1,KU) - UN(IJK5)=-F(1,1,KU) - VN(IJK5)=-F(1,1,KV) - UN(IJK7)=-F(1,1,KV) - VN(IJK7)= F(1,1,KU) - US(IJK1)=-F(1,2,KU) - VS(IJK1)=-F(1,2,KV) - US(IJK3)=-F(1,2,KV) - VS(IJK3)= F(1,2,KU) - US(IJK5)= F(1,2,KU) - VS(IJK5)= F(1,2,KV) - US(IJK7)= F(1,2,KV) - VS(IJK7)=-F(1,2,KU) - ENDDO - IF(KMAX.EQ.1) THEN - KU=1 - KV=2 - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 - UN(IJ1)=UN(IJ1)+2*(F(LR,1,KU)*CLON(L,1) - & -F(LI,1,KU)*SLON(L,1)) - VN(IJ1)=VN(IJ1)+2*(F(LR,1,KV)*CLON(L,1) - & -F(LI,1,KV)*SLON(L,1)) - UN(IJ3)=UN(IJ3)+2*(F(LR,1,KV)*CLON(L,3) - & -F(LI,1,KV)*SLON(L,3)) - VN(IJ3)=VN(IJ3)-2*(F(LR,1,KU)*CLON(L,3) - & -F(LI,1,KU)*SLON(L,3)) - UN(IJ5)=UN(IJ5)-2*(F(LR,1,KU)*CLON(L,5) - & -F(LI,1,KU)*SLON(L,5)) - VN(IJ5)=VN(IJ5)-2*(F(LR,1,KV)*CLON(L,5) - & -F(LI,1,KV)*SLON(L,5)) - UN(IJ7)=UN(IJ7)-2*(F(LR,1,KV)*CLON(L,7) - & -F(LI,1,KV)*SLON(L,7)) - VN(IJ7)=VN(IJ7)+2*(F(LR,1,KU)*CLON(L,7) - & -F(LI,1,KU)*SLON(L,7)) - US(IJ1)=US(IJ1)-2*(F(LR,2,KU)*CLON(L,5) - & -F(LI,2,KU)*SLON(L,5)) - VS(IJ1)=VS(IJ1)-2*(F(LR,2,KV)*CLON(L,5) - & -F(LI,2,KV)*SLON(L,5)) - US(IJ3)=US(IJ3)-2*(F(LR,2,KV)*CLON(L,3) - & -F(LI,2,KV)*SLON(L,3)) - VS(IJ3)=VS(IJ3)+2*(F(LR,2,KU)*CLON(L,3) - & -F(LI,2,KU)*SLON(L,3)) - US(IJ5)=US(IJ5)+2*(F(LR,2,KU)*CLON(L,1) - & -F(LI,2,KU)*SLON(L,1)) - VS(IJ5)=VS(IJ5)+2*(F(LR,2,KV)*CLON(L,1) - & -F(LI,2,KV)*SLON(L,1)) - US(IJ7)=US(IJ7)+2*(F(LR,2,KV)*CLON(L,7) - & -F(LI,2,KV)*SLON(L,7)) - VS(IJ7)=VS(IJ7)-2*(F(LR,2,KU)*CLON(L,7) - & -F(LI,2,KU)*SLON(L,7)) - ENDDO - ELSE - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 -CDIR$ IVDEP - DO K=1,KMAX - KU=K - KV=K+KMAX - IJK1=IJ1+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK7=IJ7+(K-1)*KG - UN(IJK1)=UN(IJK1)+2*(F(LR,1,KU)*CLON(L,1) - & -F(LI,1,KU)*SLON(L,1)) - VN(IJK1)=VN(IJK1)+2*(F(LR,1,KV)*CLON(L,1) - & -F(LI,1,KV)*SLON(L,1)) - UN(IJK3)=UN(IJK3)+2*(F(LR,1,KV)*CLON(L,3) - & -F(LI,1,KV)*SLON(L,3)) - VN(IJK3)=VN(IJK3)-2*(F(LR,1,KU)*CLON(L,3) - & -F(LI,1,KU)*SLON(L,3)) - UN(IJK5)=UN(IJK5)-2*(F(LR,1,KU)*CLON(L,5) - & -F(LI,1,KU)*SLON(L,5)) - VN(IJK5)=VN(IJK5)-2*(F(LR,1,KV)*CLON(L,5) - & -F(LI,1,KV)*SLON(L,5)) - UN(IJK7)=UN(IJK7)-2*(F(LR,1,KV)*CLON(L,7) - & -F(LI,1,KV)*SLON(L,7)) - VN(IJK7)=VN(IJK7)+2*(F(LR,1,KU)*CLON(L,7) - & -F(LI,1,KU)*SLON(L,7)) - US(IJK1)=US(IJK1)-2*(F(LR,2,KU)*CLON(L,5) - & -F(LI,2,KU)*SLON(L,5)) - VS(IJK1)=VS(IJK1)-2*(F(LR,2,KV)*CLON(L,5) - & -F(LI,2,KV)*SLON(L,5)) - US(IJK3)=US(IJK3)-2*(F(LR,2,KV)*CLON(L,3) - & -F(LI,2,KV)*SLON(L,3)) - VS(IJK3)=VS(IJK3)+2*(F(LR,2,KU)*CLON(L,3) - & -F(LI,2,KU)*SLON(L,3)) - US(IJK5)=US(IJK5)+2*(F(LR,2,KU)*CLON(L,1) - & -F(LI,2,KU)*SLON(L,1)) - VS(IJK5)=VS(IJK5)+2*(F(LR,2,KV)*CLON(L,1) - & -F(LI,2,KV)*SLON(L,1)) - US(IJK7)=US(IJK7)+2*(F(LR,2,KV)*CLON(L,7) - & -F(LI,2,KV)*SLON(L,7)) - VS(IJK7)=VS(IJK7)-2*(F(LR,2,KU)*CLON(L,7) - & -F(LI,2,KU)*SLON(L,7)) - ENDDO - ENDDO - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE POINTS ON THE MAIN DIAGONALS THROUGH THE POLE, -C STARTING CLOCKWISE OF THE ORIENTATION LONGITUDE AND GOING CLOCKWISE. -C$OMP PARALLEL DO PRIVATE(I1,J2,I2,J3,I3,J4,I4,J5,I5,J6,I6,J7,I7,J8,I8) -C$OMP& PRIVATE(IJ1,IJ2,IJ3,IJ4,IJ5,IJ6,IJ7,IJ8) -C$OMP& PRIVATE(IJK1,IJK2,IJK3,IJK4,IJK5,IJK6,IJK7,IJK8) -C$OMP& PRIVATE(DJ1,DI1,RQ,RR,RADLON,RADLON1,RADLON2,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,SLON,CLON,KU,KV,LR,LI) - DO J1=1,NPH - I1=J1 - RADLON=(ORIENT-45)/DPR - J3=NPS+1-I1 - I3=J1 - J5=NPS+1-J1 - I5=NPS+1-I1 - J7=I1 - I7=NPS+1-J1 - IJ1=(I1-1)*NI+(J1-1)*NJ+1 - IJ3=(I3-1)*NI+(J3-1)*NJ+1 - IJ5=(I5-1)*NI+(J5-1)*NJ+1 - IJ7=(I7-1)*NI+(J7-1)*NJ+1 - DI1=I1-NPH-1 - DJ1=J1-NPH-1 - RQ=DI1**2+DJ1**2 - SLAT1=(GQ-RQ)/(GQ+RQ) - CLAT1=SQRT(1.-SLAT1**2) - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,MDIM,2*MXTOP,2*KMAX, - & CLAT1,PLN,PLNTOP,MP,W,WTOP,F) - DO L=1,MAXWV - SLON(L,1)=SIN(L*RADLON) - CLON(L,1)=COS(L*RADLON) - SLON(L,3)=SLON(L,1)*CROT(MOD(1*L,4)) - & -CLON(L,1)*SROT(MOD(1*L,4)) - CLON(L,3)=CLON(L,1)*CROT(MOD(1*L,4)) - & +SLON(L,1)*SROT(MOD(1*L,4)) - SLON(L,5)=SLON(L,1)*CROT(MOD(2*L,4)) - & -CLON(L,1)*SROT(MOD(2*L,4)) - CLON(L,5)=CLON(L,1)*CROT(MOD(2*L,4)) - & +SLON(L,1)*SROT(MOD(2*L,4)) - SLON(L,7)=SLON(L,1)*CROT(MOD(3*L,4)) - & -CLON(L,1)*SROT(MOD(3*L,4)) - CLON(L,7)=CLON(L,1)*CROT(MOD(3*L,4)) - & +SLON(L,1)*SROT(MOD(3*L,4)) - ENDDO -CDIR$ IVDEP - DO K=1,KMAX - KU=K - KV=K+KMAX - IJK1=IJ1+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK7=IJ7+(K-1)*KG - UN(IJK1)=SRH*( F(1,1,KU)+F(1,1,KV)) - VN(IJK1)=SRH*(-F(1,1,KU)+F(1,1,KV)) - UN(IJK3)=SRH*(-F(1,1,KU)+F(1,1,KV)) - VN(IJK3)=SRH*(-F(1,1,KU)-F(1,1,KV)) - UN(IJK5)=SRH*(-F(1,1,KU)-F(1,1,KV)) - VN(IJK5)=SRH*( F(1,1,KU)-F(1,1,KV)) - UN(IJK7)=SRH*( F(1,1,KU)-F(1,1,KV)) - VN(IJK7)=SRH*( F(1,1,KU)+F(1,1,KV)) - US(IJK1)=SRH*(-F(1,2,KU)-F(1,2,KV)) - VS(IJK1)=SRH*( F(1,2,KU)-F(1,2,KV)) - US(IJK3)=SRH*( F(1,2,KU)-F(1,2,KV)) - VS(IJK3)=SRH*( F(1,2,KU)+F(1,2,KV)) - US(IJK5)=SRH*( F(1,2,KU)+F(1,2,KV)) - VS(IJK5)=SRH*(-F(1,2,KU)+F(1,2,KV)) - US(IJK7)=SRH*(-F(1,2,KU)+F(1,2,KV)) - VS(IJK7)=SRH*(-F(1,2,KU)-F(1,2,KV)) - ENDDO - IF(KMAX.EQ.1) THEN - KU=1 - KV=2 - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 - UN(IJ1)=UN(IJ1)+2*SRH*(( F(LR,1,KU)+F(LR,1,KV)) - & *CLON(L,1) - & -( F(LI,1,KU)+F(LI,1,KV)) - & *SLON(L,1)) - VN(IJ1)=VN(IJ1)+2*SRH*((-F(LR,1,KU)+F(LR,1,KV)) - & *CLON(L,1) - & -(-F(LI,1,KU)+F(LI,1,KV)) - & *SLON(L,1)) - UN(IJ3)=UN(IJ3)+2*SRH*((-F(LR,1,KU)+F(LR,1,KV)) - & *CLON(L,3) - & -(-F(LI,1,KU)+F(LI,1,KV)) - & *SLON(L,3)) - VN(IJ3)=VN(IJ3)+2*SRH*((-F(LR,1,KU)-F(LR,1,KV)) - & *CLON(L,3) - & -(-F(LI,1,KU)-F(LI,1,KV)) - & *SLON(L,3)) - UN(IJ5)=UN(IJ5)+2*SRH*((-F(LR,1,KU)-F(LR,1,KV)) - & *CLON(L,5) - & -(-F(LI,1,KU)-F(LI,1,KV)) - & *SLON(L,5)) - VN(IJ5)=VN(IJ5)+2*SRH*(( F(LR,1,KU)-F(LR,1,KV)) - & *CLON(L,5) - & -( F(LI,1,KU)-F(LI,1,KV)) - & *SLON(L,5)) - UN(IJ7)=UN(IJ7)+2*SRH*(( F(LR,1,KU)-F(LR,1,KV)) - & *CLON(L,7) - & -( F(LI,1,KU)-F(LI,1,KV)) - & *SLON(L,7)) - VN(IJ7)=VN(IJ7)+2*SRH*(( F(LR,1,KU)+F(LR,1,KV)) - & *CLON(L,7) - & -( F(LI,1,KU)+F(LI,1,KV)) - & *SLON(L,7)) - US(IJ1)=US(IJ1)+2*SRH*((-F(LR,2,KU)-F(LR,2,KV)) - & *CLON(L,3) - & -(-F(LI,2,KU)-F(LI,2,KV)) - & *SLON(L,3)) - VS(IJ1)=VS(IJ1)+2*SRH*(( F(LR,2,KU)-F(LR,2,KV)) - & *CLON(L,3) - & -( F(LI,2,KU)-F(LI,2,KV)) - & *SLON(L,3)) - US(IJ3)=US(IJ3)+2*SRH*(( F(LR,2,KU)-F(LR,2,KV)) - & *CLON(L,1) - & -( F(LI,2,KU)-F(LI,2,KV)) - & *SLON(L,1)) - VS(IJ3)=VS(IJ3)+2*SRH*(( F(LR,2,KU)+F(LR,2,KV)) - & *CLON(L,1) - & -( F(LI,2,KU)+F(LI,2,KV)) - & *SLON(L,1)) - US(IJ5)=US(IJ5)+2*SRH*(( F(LR,2,KU)+F(LR,2,KV)) - & *CLON(L,7) - & -( F(LI,2,KU)+F(LI,2,KV)) - & *SLON(L,7)) - VS(IJ5)=VS(IJ5)+2*SRH*((-F(LR,2,KU)+F(LR,2,KV)) - & *CLON(L,7) - & -(-F(LI,2,KU)+F(LI,2,KV)) - & *SLON(L,7)) - US(IJ7)=US(IJ7)+2*SRH*((-F(LR,2,KU)+F(LR,2,KV)) - & *CLON(L,5) - & -(-F(LI,2,KU)+F(LI,2,KV)) - & *SLON(L,5)) - VS(IJ7)=VS(IJ7)+2*SRH*((-F(LR,2,KU)-F(LR,2,KV)) - & *CLON(L,5) - & -(-F(LI,2,KU)-F(LI,2,KV)) - & *SLON(L,5)) - ENDDO - ELSE - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 -CDIR$ IVDEP - DO K=1,KMAX - KU=K - KV=K+KMAX - IJK1=IJ1+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK7=IJ7+(K-1)*KG - UN(IJK1)=UN(IJK1)+2*SRH*(( F(LR,1,KU)+F(LR,1,KV)) - & *CLON(L,1) - & -( F(LI,1,KU)+F(LI,1,KV)) - & *SLON(L,1)) - VN(IJK1)=VN(IJK1)+2*SRH*((-F(LR,1,KU)+F(LR,1,KV)) - & *CLON(L,1) - & -(-F(LI,1,KU)+F(LI,1,KV)) - & *SLON(L,1)) - UN(IJK3)=UN(IJK3)+2*SRH*((-F(LR,1,KU)+F(LR,1,KV)) - & *CLON(L,3) - & -(-F(LI,1,KU)+F(LI,1,KV)) - & *SLON(L,3)) - VN(IJK3)=VN(IJK3)+2*SRH*((-F(LR,1,KU)-F(LR,1,KV)) - & *CLON(L,3) - & -(-F(LI,1,KU)-F(LI,1,KV)) - & *SLON(L,3)) - UN(IJK5)=UN(IJK5)+2*SRH*((-F(LR,1,KU)-F(LR,1,KV)) - & *CLON(L,5) - & -(-F(LI,1,KU)-F(LI,1,KV)) - & *SLON(L,5)) - VN(IJK5)=VN(IJK5)+2*SRH*(( F(LR,1,KU)-F(LR,1,KV)) - & *CLON(L,5) - & -( F(LI,1,KU)-F(LI,1,KV)) - & *SLON(L,5)) - UN(IJK7)=UN(IJK7)+2*SRH*(( F(LR,1,KU)-F(LR,1,KV)) - & *CLON(L,7) - & -( F(LI,1,KU)-F(LI,1,KV)) - & *SLON(L,7)) - VN(IJK7)=VN(IJK7)+2*SRH*(( F(LR,1,KU)+F(LR,1,KV)) - & *CLON(L,7) - & -( F(LI,1,KU)+F(LI,1,KV)) - & *SLON(L,7)) - US(IJK1)=US(IJK1)+2*SRH*((-F(LR,2,KU)-F(LR,2,KV)) - & *CLON(L,3) - & -(-F(LI,2,KU)-F(LI,2,KV)) - & *SLON(L,3)) - VS(IJK1)=VS(IJK1)+2*SRH*(( F(LR,2,KU)-F(LR,2,KV)) - & *CLON(L,3) - & -( F(LI,2,KU)-F(LI,2,KV)) - & *SLON(L,3)) - US(IJK3)=US(IJK3)+2*SRH*(( F(LR,2,KU)-F(LR,2,KV)) - & *CLON(L,1) - & -( F(LI,2,KU)-F(LI,2,KV)) - & *SLON(L,1)) - VS(IJK3)=VS(IJK3)+2*SRH*(( F(LR,2,KU)+F(LR,2,KV)) - & *CLON(L,1) - & -( F(LI,2,KU)+F(LI,2,KV)) - & *SLON(L,1)) - US(IJK5)=US(IJK5)+2*SRH*(( F(LR,2,KU)+F(LR,2,KV)) - & *CLON(L,7) - & -( F(LI,2,KU)+F(LI,2,KV)) - & *SLON(L,7)) - VS(IJK5)=VS(IJK5)+2*SRH*((-F(LR,2,KU)+F(LR,2,KV)) - & *CLON(L,7) - & -(-F(LI,2,KU)+F(LI,2,KV)) - & *SLON(L,7)) - US(IJK7)=US(IJK7)+2*SRH*((-F(LR,2,KU)+F(LR,2,KV)) - & *CLON(L,5) - & -(-F(LI,2,KU)+F(LI,2,KV)) - & *SLON(L,5)) - VS(IJK7)=VS(IJK7)+2*SRH*((-F(LR,2,KU)-F(LR,2,KV)) - & *CLON(L,5) - & -(-F(LI,2,KU)-F(LI,2,KV)) - & *SLON(L,5)) - ENDDO - ENDDO - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE THE REMAINDER OF THE POLAR STEREOGRAPHIC DOMAIN, -C STARTING AT THE SECTOR JUST CLOCKWISE OF THE ORIENTATION LONGITUDE -C AND GOING CLOCKWISE UNTIL ALL EIGHT SECTORS ARE DONE. -C$OMP PARALLEL DO PRIVATE(I1,J2,I2,J3,I3,J4,I4,J5,I5,J6,I6,J7,I7,J8,I8) -C$OMP& PRIVATE(IJ1,IJ2,IJ3,IJ4,IJ5,IJ6,IJ7,IJ8) -C$OMP& PRIVATE(IJK1,IJK2,IJK3,IJK4,IJK5,IJK6,IJK7,IJK8) -C$OMP& PRIVATE(DJ1,DI1,RQ,RR,RADLON,RADLON1,RADLON2,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,SLON,CLON,KU,KV,LR,LI) - DO J1=1,NPH-1 - DO I1=J1+1,NPH - J2=I1 - I2=J1 - J3=NPS+1-I1 - I3=J1 - J4=NPS+1-J1 - I4=I1 - J5=NPS+1-J1 - I5=NPS+1-I1 - J6=NPS+1-I1 - I6=NPS+1-J1 - J7=I1 - I7=NPS+1-J1 - J8=J1 - I8=NPS+1-I1 - IJ1=(I1-1)*NI+(J1-1)*NJ+1 - IJ2=(I2-1)*NI+(J2-1)*NJ+1 - IJ3=(I3-1)*NI+(J3-1)*NJ+1 - IJ4=(I4-1)*NI+(J4-1)*NJ+1 - IJ5=(I5-1)*NI+(J5-1)*NJ+1 - IJ6=(I6-1)*NI+(J6-1)*NJ+1 - IJ7=(I7-1)*NI+(J7-1)*NJ+1 - IJ8=(I8-1)*NI+(J8-1)*NJ+1 - DI1=I1-NPH-1 - DJ1=J1-NPH-1 - RQ=DI1**2+DJ1**2 - RR=SQRT(1/RQ) - SLAT1=(GQ-RQ)/(GQ+RQ) - CLAT1=SQRT(1.-SLAT1**2) - RADLON1=ORIENT/DPR+ATAN(-DI1/DJ1) - RADLON2=(ORIENT-45)/DPR*2-RADLON1 - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,MDIM,2*MXTOP,2*KMAX, - & CLAT1,PLN,PLNTOP,MP,W,WTOP,F) - DO L=1,MAXWV - SLON(L,1)=SIN(L*RADLON1) - CLON(L,1)=COS(L*RADLON1) - SLON(L,2)=SIN(L*RADLON2) - CLON(L,2)=COS(L*RADLON2) - SLON(L,3)=SLON(L,1)*CROT(MOD(1*L,4)) - & -CLON(L,1)*SROT(MOD(1*L,4)) - CLON(L,3)=CLON(L,1)*CROT(MOD(1*L,4)) - & +SLON(L,1)*SROT(MOD(1*L,4)) - SLON(L,4)=SLON(L,2)*CROT(MOD(1*L,4)) - & -CLON(L,2)*SROT(MOD(1*L,4)) - CLON(L,4)=CLON(L,2)*CROT(MOD(1*L,4)) - & +SLON(L,2)*SROT(MOD(1*L,4)) - SLON(L,5)=SLON(L,1)*CROT(MOD(2*L,4)) - & -CLON(L,1)*SROT(MOD(2*L,4)) - CLON(L,5)=CLON(L,1)*CROT(MOD(2*L,4)) - & +SLON(L,1)*SROT(MOD(2*L,4)) - SLON(L,6)=SLON(L,2)*CROT(MOD(2*L,4)) - & -CLON(L,2)*SROT(MOD(2*L,4)) - CLON(L,6)=CLON(L,2)*CROT(MOD(2*L,4)) - & +SLON(L,2)*SROT(MOD(2*L,4)) - SLON(L,7)=SLON(L,1)*CROT(MOD(3*L,4)) - & -CLON(L,1)*SROT(MOD(3*L,4)) - CLON(L,7)=CLON(L,1)*CROT(MOD(3*L,4)) - & +SLON(L,1)*SROT(MOD(3*L,4)) - SLON(L,8)=SLON(L,2)*CROT(MOD(3*L,4)) - & -CLON(L,2)*SROT(MOD(3*L,4)) - CLON(L,8)=CLON(L,2)*CROT(MOD(3*L,4)) - & +SLON(L,2)*SROT(MOD(3*L,4)) - ENDDO -CDIR$ IVDEP - DO K=1,KMAX - KU=K - KV=K+KMAX - IJK1=IJ1+(K-1)*KG - IJK2=IJ2+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK4=IJ4+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK6=IJ6+(K-1)*KG - IJK7=IJ7+(K-1)*KG - IJK8=IJ8+(K-1)*KG - UN(IJK1)=RR*(-DJ1*F(1,1,KU)-DI1*F(1,1,KV)) - VN(IJK1)=RR*( DI1*F(1,1,KU)-DJ1*F(1,1,KV)) - UN(IJK2)=RR*(-DI1*F(1,1,KU)-DJ1*F(1,1,KV)) - VN(IJK2)=RR*( DJ1*F(1,1,KU)-DI1*F(1,1,KV)) - UN(IJK3)=RR*( DI1*F(1,1,KU)-DJ1*F(1,1,KV)) - VN(IJK3)=RR*( DJ1*F(1,1,KU)+DI1*F(1,1,KV)) - UN(IJK4)=RR*( DJ1*F(1,1,KU)-DI1*F(1,1,KV)) - VN(IJK4)=RR*( DI1*F(1,1,KU)+DJ1*F(1,1,KV)) - UN(IJK5)=RR*( DJ1*F(1,1,KU)+DI1*F(1,1,KV)) - VN(IJK5)=RR*(-DI1*F(1,1,KU)+DJ1*F(1,1,KV)) - UN(IJK6)=RR*( DI1*F(1,1,KU)+DJ1*F(1,1,KV)) - VN(IJK6)=RR*(-DJ1*F(1,1,KU)+DI1*F(1,1,KV)) - UN(IJK7)=RR*(-DI1*F(1,1,KU)+DJ1*F(1,1,KV)) - VN(IJK7)=RR*(-DJ1*F(1,1,KU)-DI1*F(1,1,KV)) - UN(IJK8)=RR*(-DJ1*F(1,1,KU)+DI1*F(1,1,KV)) - VN(IJK8)=RR*(-DI1*F(1,1,KU)-DJ1*F(1,1,KV)) - US(IJK1)=RR*( DJ1*F(1,2,KU)+DI1*F(1,2,KV)) - VS(IJK1)=RR*(-DI1*F(1,2,KU)+DJ1*F(1,2,KV)) - US(IJK2)=RR*( DI1*F(1,2,KU)+DJ1*F(1,2,KV)) - VS(IJK2)=RR*(-DJ1*F(1,2,KU)+DI1*F(1,2,KV)) - US(IJK3)=RR*(-DI1*F(1,2,KU)+DJ1*F(1,2,KV)) - VS(IJK3)=RR*(-DJ1*F(1,2,KU)-DI1*F(1,2,KV)) - US(IJK4)=RR*(-DJ1*F(1,2,KU)+DI1*F(1,2,KV)) - VS(IJK4)=RR*(-DI1*F(1,2,KU)-DJ1*F(1,2,KV)) - US(IJK5)=RR*(-DJ1*F(1,2,KU)-DI1*F(1,2,KV)) - VS(IJK5)=RR*( DI1*F(1,2,KU)-DJ1*F(1,2,KV)) - US(IJK6)=RR*(-DI1*F(1,2,KU)-DJ1*F(1,2,KV)) - VS(IJK6)=RR*( DJ1*F(1,2,KU)-DI1*F(1,2,KV)) - US(IJK7)=RR*( DI1*F(1,2,KU)-DJ1*F(1,2,KV)) - VS(IJK7)=RR*( DJ1*F(1,2,KU)+DI1*F(1,2,KV)) - US(IJK8)=RR*( DJ1*F(1,2,KU)-DI1*F(1,2,KV)) - VS(IJK8)=RR*( DI1*F(1,2,KU)+DJ1*F(1,2,KV)) - ENDDO - IF(KMAX.EQ.1) THEN - KU=1 - KV=2 - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 - UN(IJ1)=UN(IJ1)+2*RR*((-DJ1*F(LR,1,KU)-DI1*F(LR,1,KV)) - & *CLON(L,1) - & -(-DJ1*F(LI,1,KU)-DI1*F(LI,1,KV)) - & *SLON(L,1)) - VN(IJ1)=VN(IJ1)+2*RR*(( DI1*F(LR,1,KU)-DJ1*F(LR,1,KV)) - & *CLON(L,1) - & -( DI1*F(LI,1,KU)-DJ1*F(LI,1,KV)) - & *SLON(L,1)) - UN(IJ2)=UN(IJ2)+2*RR*((-DI1*F(LR,1,KU)-DJ1*F(LR,1,KV)) - & *CLON(L,2) - & -(-DI1*F(LI,1,KU)-DJ1*F(LI,1,KV)) - & *SLON(L,2)) - VN(IJ2)=VN(IJ2)+2*RR*(( DJ1*F(LR,1,KU)-DI1*F(LR,1,KV)) - & *CLON(L,2) - & -( DJ1*F(LI,1,KU)-DI1*F(LI,1,KV)) - & *SLON(L,2)) - UN(IJ3)=UN(IJ3)+2*RR*(( DI1*F(LR,1,KU)-DJ1*F(LR,1,KV)) - & *CLON(L,3) - & -( DI1*F(LI,1,KU)-DJ1*F(LI,1,KV)) - & *SLON(L,3)) - VN(IJ3)=VN(IJ3)+2*RR*(( DJ1*F(LR,1,KU)+DI1*F(LR,1,KV)) - & *CLON(L,3) - & -( DJ1*F(LI,1,KU)+DI1*F(LI,1,KV)) - & *SLON(L,3)) - UN(IJ4)=UN(IJ4)+2*RR*(( DJ1*F(LR,1,KU)-DI1*F(LR,1,KV)) - & *CLON(L,4) - & -( DJ1*F(LI,1,KU)-DI1*F(LI,1,KV)) - & *SLON(L,4)) - VN(IJ4)=VN(IJ4)+2*RR*(( DI1*F(LR,1,KU)+DJ1*F(LR,1,KV)) - & *CLON(L,4) - & -( DI1*F(LI,1,KU)+DJ1*F(LI,1,KV)) - & *SLON(L,4)) - UN(IJ5)=UN(IJ5)+2*RR*(( DJ1*F(LR,1,KU)+DI1*F(LR,1,KV)) - & *CLON(L,5) - & -( DJ1*F(LI,1,KU)+DI1*F(LI,1,KV)) - & *SLON(L,5)) - VN(IJ5)=VN(IJ5)+2*RR*((-DI1*F(LR,1,KU)+DJ1*F(LR,1,KV)) - & *CLON(L,5) - & -(-DI1*F(LI,1,KU)+DJ1*F(LI,1,KV)) - & *SLON(L,5)) - UN(IJ6)=UN(IJ6)+2*RR*(( DI1*F(LR,1,KU)+DJ1*F(LR,1,KV)) - & *CLON(L,6) - & -( DI1*F(LI,1,KU)+DJ1*F(LI,1,KV)) - & *SLON(L,6)) - VN(IJ6)=VN(IJ6)+2*RR*((-DJ1*F(LR,1,KU)+DI1*F(LR,1,KV)) - & *CLON(L,6) - & -(-DJ1*F(LI,1,KU)+DI1*F(LI,1,KV)) - & *SLON(L,6)) - UN(IJ7)=UN(IJ7)+2*RR*((-DI1*F(LR,1,KU)+DJ1*F(LR,1,KV)) - & *CLON(L,7) - & -(-DI1*F(LI,1,KU)+DJ1*F(LI,1,KV)) - & *SLON(L,7)) - VN(IJ7)=VN(IJ7)+2*RR*((-DJ1*F(LR,1,KU)-DI1*F(LR,1,KV)) - & *CLON(L,7) - & -(-DJ1*F(LI,1,KU)-DI1*F(LI,1,KV)) - & *SLON(L,7)) - UN(IJ8)=UN(IJ8)+2*RR*((-DJ1*F(LR,1,KU)+DI1*F(LR,1,KV)) - & *CLON(L,8) - & -(-DJ1*F(LI,1,KU)+DI1*F(LI,1,KV)) - & *SLON(L,8)) - VN(IJ8)=VN(IJ8)+2*RR*((-DI1*F(LR,1,KU)-DJ1*F(LR,1,KV)) - & *CLON(L,8) - & -(-DI1*F(LI,1,KU)-DJ1*F(LI,1,KV)) - & *SLON(L,8)) - US(IJ1)=US(IJ1)+2*RR*(( DJ1*F(LR,2,KU)+DI1*F(LR,2,KV)) - & *CLON(L,4) - & -( DJ1*F(LI,2,KU)+DI1*F(LI,2,KV)) - & *SLON(L,4)) - VS(IJ1)=VS(IJ1)+2*RR*((-DI1*F(LR,2,KU)+DJ1*F(LR,2,KV)) - & *CLON(L,4) - & -(-DI1*F(LI,2,KU)+DJ1*F(LI,2,KV)) - & *SLON(L,4)) - US(IJ2)=US(IJ2)+2*RR*(( DI1*F(LR,2,KU)+DJ1*F(LR,2,KV)) - & *CLON(L,3) - & -( DI1*F(LI,2,KU)+DJ1*F(LI,2,KV)) - & *SLON(L,3)) - VS(IJ2)=VS(IJ2)+2*RR*((-DJ1*F(LR,2,KU)+DI1*F(LR,2,KV)) - & *CLON(L,3) - & -(-DJ1*F(LI,2,KU)+DI1*F(LI,2,KV)) - & *SLON(L,3)) - US(IJ3)=US(IJ3)+2*RR*((-DI1*F(LR,2,KU)+DJ1*F(LR,2,KV)) - & *CLON(L,2) - & -(-DI1*F(LI,2,KU)+DJ1*F(LI,2,KV)) - & *SLON(L,2)) - VS(IJ3)=VS(IJ3)+2*RR*((-DJ1*F(LR,2,KU)-DI1*F(LR,2,KV)) - & *CLON(L,2) - & -(-DJ1*F(LI,2,KU)-DI1*F(LI,2,KV)) - & *SLON(L,2)) - US(IJ4)=US(IJ4)+2*RR*((-DJ1*F(LR,2,KU)+DI1*F(LR,2,KV)) - & *CLON(L,1) - & -(-DJ1*F(LI,2,KU)+DI1*F(LI,2,KV)) - & *SLON(L,1)) - VS(IJ4)=VS(IJ4)+2*RR*((-DI1*F(LR,2,KU)-DJ1*F(LR,2,KV)) - & *CLON(L,1) - & -(-DI1*F(LI,2,KU)-DJ1*F(LI,2,KV)) - & *SLON(L,1)) - US(IJ5)=US(IJ5)+2*RR*((-DJ1*F(LR,2,KU)-DI1*F(LR,2,KV)) - & *CLON(L,8) - & -(-DJ1*F(LI,2,KU)-DI1*F(LI,2,KV)) - & *SLON(L,8)) - VS(IJ5)=VS(IJ5)+2*RR*(( DI1*F(LR,2,KU)-DJ1*F(LR,2,KV)) - & *CLON(L,8) - & -( DI1*F(LI,2,KU)-DJ1*F(LI,2,KV)) - & *SLON(L,8)) - US(IJ6)=US(IJ6)+2*RR*((-DI1*F(LR,2,KU)-DJ1*F(LR,2,KV)) - & *CLON(L,7) - & -(-DI1*F(LI,2,KU)-DJ1*F(LI,2,KV)) - & *SLON(L,7)) - VS(IJ6)=VS(IJ6)+2*RR*(( DJ1*F(LR,2,KU)-DI1*F(LR,2,KV)) - & *CLON(L,7) - & -( DJ1*F(LI,2,KU)-DI1*F(LI,2,KV)) - & *SLON(L,7)) - US(IJ7)=US(IJ7)+2*RR*(( DI1*F(LR,2,KU)-DJ1*F(LR,2,KV)) - & *CLON(L,6) - & -( DI1*F(LI,2,KU)-DJ1*F(LI,2,KV)) - & *SLON(L,6)) - VS(IJ7)=VS(IJ7)+2*RR*(( DJ1*F(LR,2,KU)+DI1*F(LR,2,KV)) - & *CLON(L,6) - & -( DJ1*F(LI,2,KU)+DI1*F(LI,2,KV)) - & *SLON(L,6)) - US(IJ8)=US(IJ8)+2*RR*(( DJ1*F(LR,2,KU)-DI1*F(LR,2,KV)) - & *CLON(L,5) - & -( DJ1*F(LI,2,KU)-DI1*F(LI,2,KV)) - & *SLON(L,5)) - VS(IJ8)=VS(IJ8)+2*RR*(( DI1*F(LR,2,KU)+DJ1*F(LR,2,KV)) - & *CLON(L,5) - & -( DI1*F(LI,2,KU)+DJ1*F(LI,2,KV)) - & *SLON(L,5)) - ENDDO - ELSE - DO L=1,MAXWV - LR=2*L+1 - LI=2*L+2 -CDIR$ IVDEP - DO K=1,KMAX - KU=K - KV=K+KMAX - IJK1=IJ1+(K-1)*KG - IJK2=IJ2+(K-1)*KG - IJK3=IJ3+(K-1)*KG - IJK4=IJ4+(K-1)*KG - IJK5=IJ5+(K-1)*KG - IJK6=IJ6+(K-1)*KG - IJK7=IJ7+(K-1)*KG - IJK8=IJ8+(K-1)*KG - UN(IJK1)=UN(IJK1)+2*RR*((-DJ1*F(LR,1,KU)-DI1*F(LR,1,KV)) - & *CLON(L,1) - & -(-DJ1*F(LI,1,KU)-DI1*F(LI,1,KV)) - & *SLON(L,1)) - VN(IJK1)=VN(IJK1)+2*RR*(( DI1*F(LR,1,KU)-DJ1*F(LR,1,KV)) - & *CLON(L,1) - & -( DI1*F(LI,1,KU)-DJ1*F(LI,1,KV)) - & *SLON(L,1)) - UN(IJK2)=UN(IJK2)+2*RR*((-DI1*F(LR,1,KU)-DJ1*F(LR,1,KV)) - & *CLON(L,2) - & -(-DI1*F(LI,1,KU)-DJ1*F(LI,1,KV)) - & *SLON(L,2)) - VN(IJK2)=VN(IJK2)+2*RR*(( DJ1*F(LR,1,KU)-DI1*F(LR,1,KV)) - & *CLON(L,2) - & -( DJ1*F(LI,1,KU)-DI1*F(LI,1,KV)) - & *SLON(L,2)) - UN(IJK3)=UN(IJK3)+2*RR*(( DI1*F(LR,1,KU)-DJ1*F(LR,1,KV)) - & *CLON(L,3) - & -( DI1*F(LI,1,KU)-DJ1*F(LI,1,KV)) - & *SLON(L,3)) - VN(IJK3)=VN(IJK3)+2*RR*(( DJ1*F(LR,1,KU)+DI1*F(LR,1,KV)) - & *CLON(L,3) - & -( DJ1*F(LI,1,KU)+DI1*F(LI,1,KV)) - & *SLON(L,3)) - UN(IJK4)=UN(IJK4)+2*RR*(( DJ1*F(LR,1,KU)-DI1*F(LR,1,KV)) - & *CLON(L,4) - & -( DJ1*F(LI,1,KU)-DI1*F(LI,1,KV)) - & *SLON(L,4)) - VN(IJK4)=VN(IJK4)+2*RR*(( DI1*F(LR,1,KU)+DJ1*F(LR,1,KV)) - & *CLON(L,4) - & -( DI1*F(LI,1,KU)+DJ1*F(LI,1,KV)) - & *SLON(L,4)) - UN(IJK5)=UN(IJK5)+2*RR*(( DJ1*F(LR,1,KU)+DI1*F(LR,1,KV)) - & *CLON(L,5) - & -( DJ1*F(LI,1,KU)+DI1*F(LI,1,KV)) - & *SLON(L,5)) - VN(IJK5)=VN(IJK5)+2*RR*((-DI1*F(LR,1,KU)+DJ1*F(LR,1,KV)) - & *CLON(L,5) - & -(-DI1*F(LI,1,KU)+DJ1*F(LI,1,KV)) - & *SLON(L,5)) - UN(IJK6)=UN(IJK6)+2*RR*(( DI1*F(LR,1,KU)+DJ1*F(LR,1,KV)) - & *CLON(L,6) - & -( DI1*F(LI,1,KU)+DJ1*F(LI,1,KV)) - & *SLON(L,6)) - VN(IJK6)=VN(IJK6)+2*RR*((-DJ1*F(LR,1,KU)+DI1*F(LR,1,KV)) - & *CLON(L,6) - & -(-DJ1*F(LI,1,KU)+DI1*F(LI,1,KV)) - & *SLON(L,6)) - UN(IJK7)=UN(IJK7)+2*RR*((-DI1*F(LR,1,KU)+DJ1*F(LR,1,KV)) - & *CLON(L,7) - & -(-DI1*F(LI,1,KU)+DJ1*F(LI,1,KV)) - & *SLON(L,7)) - VN(IJK7)=VN(IJK7)+2*RR*((-DJ1*F(LR,1,KU)-DI1*F(LR,1,KV)) - & *CLON(L,7) - & -(-DJ1*F(LI,1,KU)-DI1*F(LI,1,KV)) - & *SLON(L,7)) - UN(IJK8)=UN(IJK8)+2*RR*((-DJ1*F(LR,1,KU)+DI1*F(LR,1,KV)) - & *CLON(L,8) - & -(-DJ1*F(LI,1,KU)+DI1*F(LI,1,KV)) - & *SLON(L,8)) - VN(IJK8)=VN(IJK8)+2*RR*((-DI1*F(LR,1,KU)-DJ1*F(LR,1,KV)) - & *CLON(L,8) - & -(-DI1*F(LI,1,KU)-DJ1*F(LI,1,KV)) - & *SLON(L,8)) - US(IJK1)=US(IJK1)+2*RR*(( DJ1*F(LR,2,KU)+DI1*F(LR,2,KV)) - & *CLON(L,4) - & -( DJ1*F(LI,2,KU)+DI1*F(LI,2,KV)) - & *SLON(L,4)) - VS(IJK1)=VS(IJK1)+2*RR*((-DI1*F(LR,2,KU)+DJ1*F(LR,2,KV)) - & *CLON(L,4) - & -(-DI1*F(LI,2,KU)+DJ1*F(LI,2,KV)) - & *SLON(L,4)) - US(IJK2)=US(IJK2)+2*RR*(( DI1*F(LR,2,KU)+DJ1*F(LR,2,KV)) - & *CLON(L,3) - & -( DI1*F(LI,2,KU)+DJ1*F(LI,2,KV)) - & *SLON(L,3)) - VS(IJK2)=VS(IJK2)+2*RR*((-DJ1*F(LR,2,KU)+DI1*F(LR,2,KV)) - & *CLON(L,3) - & -(-DJ1*F(LI,2,KU)+DI1*F(LI,2,KV)) - & *SLON(L,3)) - US(IJK3)=US(IJK3)+2*RR*((-DI1*F(LR,2,KU)+DJ1*F(LR,2,KV)) - & *CLON(L,2) - & -(-DI1*F(LI,2,KU)+DJ1*F(LI,2,KV)) - & *SLON(L,2)) - VS(IJK3)=VS(IJK3)+2*RR*((-DJ1*F(LR,2,KU)-DI1*F(LR,2,KV)) - & *CLON(L,2) - & -(-DJ1*F(LI,2,KU)-DI1*F(LI,2,KV)) - & *SLON(L,2)) - US(IJK4)=US(IJK4)+2*RR*((-DJ1*F(LR,2,KU)+DI1*F(LR,2,KV)) - & *CLON(L,1) - & -(-DJ1*F(LI,2,KU)+DI1*F(LI,2,KV)) - & *SLON(L,1)) - VS(IJK4)=VS(IJK4)+2*RR*((-DI1*F(LR,2,KU)-DJ1*F(LR,2,KV)) - & *CLON(L,1) - & -(-DI1*F(LI,2,KU)-DJ1*F(LI,2,KV)) - & *SLON(L,1)) - US(IJK5)=US(IJK5)+2*RR*((-DJ1*F(LR,2,KU)-DI1*F(LR,2,KV)) - & *CLON(L,8) - & -(-DJ1*F(LI,2,KU)-DI1*F(LI,2,KV)) - & *SLON(L,8)) - VS(IJK5)=VS(IJK5)+2*RR*(( DI1*F(LR,2,KU)-DJ1*F(LR,2,KV)) - & *CLON(L,8) - & -( DI1*F(LI,2,KU)-DJ1*F(LI,2,KV)) - & *SLON(L,8)) - US(IJK6)=US(IJK6)+2*RR*((-DI1*F(LR,2,KU)-DJ1*F(LR,2,KV)) - & *CLON(L,7) - & -(-DI1*F(LI,2,KU)-DJ1*F(LI,2,KV)) - & *SLON(L,7)) - VS(IJK6)=VS(IJK6)+2*RR*(( DJ1*F(LR,2,KU)-DI1*F(LR,2,KV)) - & *CLON(L,7) - & -( DJ1*F(LI,2,KU)-DI1*F(LI,2,KV)) - & *SLON(L,7)) - US(IJK7)=US(IJK7)+2*RR*(( DI1*F(LR,2,KU)-DJ1*F(LR,2,KV)) - & *CLON(L,6) - & -( DI1*F(LI,2,KU)-DJ1*F(LI,2,KV)) - & *SLON(L,6)) - VS(IJK7)=VS(IJK7)+2*RR*(( DJ1*F(LR,2,KU)+DI1*F(LR,2,KV)) - & *CLON(L,6) - & -( DJ1*F(LI,2,KU)+DI1*F(LI,2,KV)) - & *SLON(L,6)) - US(IJK8)=US(IJK8)+2*RR*(( DJ1*F(LR,2,KU)-DI1*F(LR,2,KV)) - & *CLON(L,5) - & -( DJ1*F(LI,2,KU)-DI1*F(LI,2,KV)) - & *SLON(L,5)) - VS(IJK8)=VS(IJK8)+2*RR*(( DI1*F(LR,2,KU)+DJ1*F(LR,2,KV)) - & *CLON(L,5) - & -( DI1*F(LI,2,KU)+DJ1*F(LI,2,KV)) - & *SLON(L,5)) - ENDDO - ENDDO - ENDIF - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgpt.f b/external/sp/v2.0.2/src/sptgpt.f deleted file mode 100644 index 56a74e0c9..000000000 --- a/external/sp/v2.0.2/src/sptgpt.f +++ /dev/null @@ -1,112 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPT(IROMB,MAXWV,KMAX,NMAX, - & KWSKIP,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WAVE,GP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPT TRANSFORM SPECTRAL SCALAR TO STATION POINTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C TO SPECIFIED SETS OF STATION POINTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND POINT FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER STATIONS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C 2003-06-30 IREDELL USE SPFFTPT -C -C USAGE: CALL SPTGPT(IROMB,MAXWV,KMAX,NMAX, -C & KWSKIP,KGSKIP,NRSKIP,NGSKIP, -C & RLAT,RLON,WAVE,GP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C GP - REAL (*) STATION POINT SETS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPFFTPT POINTWISE FOURIER TRANSFORM -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL RLAT(*),RLON(*),WAVE(*),GP(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - INTEGER MP(KMAX) - REAL WTOP(2*(MAXWV+1),KMAX) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),PLNTOP(MAXWV+1) - REAL F(2*MAXWV+3,2,KMAX) - PARAMETER(PI=3.14159265358979) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - IDIM=2*MAXWV+3 - KW=KWSKIP - KG=KGSKIP - NR=NRSKIP - NG=NGSKIP - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=NMAX - IF(NR.EQ.0) NR=1 - IF(NG.EQ.0) NG=1 - MP=0 -C$OMP PARALLEL DO - DO K=1,KMAX - WTOP(1:2*MXTOP,K)=0 - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE STATION FIELDS -C$OMP PARALLEL DO PRIVATE(RADLAT,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,NK) - DO N=1,NMAX - RADLAT=PI/180*RLAT((N-1)*NR+1) - IF(RLAT((N-1)*NR+1).GE.89.9995) THEN - SLAT1=1. - CLAT1=0. - ELSEIF(RLAT((N-1)*NR+1).LE.-89.9995) THEN - SLAT1=-1. - CLAT1=0. - ELSE - SLAT1=SIN(RADLAT) - CLAT1=COS(RADLAT) - ENDIF - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,KW,2*MXTOP,KMAX, - & CLAT1,PLN,PLNTOP,MP,WAVE,WTOP,F) - CALL SPFFTPT(MAXWV,1,2*MAXWV+3,KG,KMAX,RLON((N-1)*NR+1), - & F,GP((N-1)*NG+1)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgptd.f b/external/sp/v2.0.2/src/sptgptd.f deleted file mode 100644 index d8c858688..000000000 --- a/external/sp/v2.0.2/src/sptgptd.f +++ /dev/null @@ -1,83 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPTD(IROMB,MAXWV,KMAX,NMAX, - & KWSKIP,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WAVE,XP,YP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPTD TRANSFORM SPECTRAL TO STATION POINT GRADIENTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C TO SPECIFIED SETS OF STATION POINT GRADIENTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND POINT FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER STATIONS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTGPTD(IROMB,MAXWV,KMAX,NMAX, -C & KWSKIP,KGSKIP,NRSKIP,NGSKIP, -C & RLAT,RLON,WAVE,XP,YP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C XP - REAL (*) STATION POINT X-GRADIENT SETS -C YP - REAL (*) STATION POINT Y-GRADIENT SETS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTGPTV TRANSFORM SPECTRAL VECTOR TO STATION POINTS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL RLAT(*),RLON(*),WAVE(*),XP(*),YP(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL WD((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL WZ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - KW=KWSKIP - IF(KW.EQ.0) KW=2*MX -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE STATION FIELDS -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WAVE(KWS+1),WD(1,K),1) - WZ(1:2*MX,K)=0. - ENDDO - CALL SPTGPTV(IROMB,MAXWV,KMAX,NMAX,MDIM,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WD,WZ,XP,YP) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgptsd.f b/external/sp/v2.0.2/src/sptgptsd.f deleted file mode 100644 index a25bbe5e8..000000000 --- a/external/sp/v2.0.2/src/sptgptsd.f +++ /dev/null @@ -1,138 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPTSD(IROMB,MAXWV,KMAX,NMAX, - & KWSKIP,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WAVE,GP,XP,YP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPTSD TRANSFORM SPECTRAL SCALAR TO STATION POINTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C TO SPECIFIED SETS OF STATION POINT VALUES -C AND THEIR GRADIENTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND POINT FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER STATIONS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C 1999-08-18 IREDELL OPENMP DIRECTIVE TYPO FIXED -C -C USAGE: CALL SPTGPTSD(IROMB,MAXWV,KMAX,NMAX, -C & KWSKIP,KGSKIP,NRSKIP,NGSKIP, -C & RLAT,RLON,WAVE,GP,XP,YP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C WAVE - REAL (*) WAVE FIELDS -C OUTPUT ARGUMENTS: -C GP - REAL (*) STATION POINT SETS -C XP - REAL (*) STATION POINT X-GRADIENT SETS -C YP - REAL (*) STATION POINT Y-GRADIENT SETS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPGRADY COMPUTE Y-GRADIENT IN SPECTRAL SPACE -C SPGRADX COMPUTE X-GRADIENT IN FOURIER SPACE -C SPFFTPT COMPUTE FOURIER TRANSFORM TO GRIDPOINTS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL RLAT(*),RLON(*),WAVE(*) - REAL GP(*),XP(*),YP(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - INTEGER MP(2*KMAX) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2,2*KMAX) - REAL WTOP(2*(MAXWV+1),2*KMAX) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),PLNTOP(MAXWV+1) - REAL F(2*MAXWV+2,2,3*KMAX),G(3*KMAX) - PARAMETER(PI=3.14159265358979) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - MDIM=2*MX - IDIM=2*MAXWV+2 - KW=KWSKIP - KG=KGSKIP - NR=NRSKIP - NG=NGSKIP - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=NMAX - IF(NR.EQ.0) NR=1 - IF(NG.EQ.0) NG=1 - MP(1:KMAX)=10 - MP(KMAX+1:2*KMAX)=1 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE SPECTRAL WINDS -C$OMP PARALLEL DO PRIVATE(KWS,KS,KY) - DO K=1,KMAX - KWS=(K-1)*KW - KS=0*KMAX+K - KY=1*KMAX+K - DO I=1,2*MX - W(I,KS)=WAVE(KWS+I) - ENDDO - DO I=1,2*MXTOP - WTOP(I,KS)=0 - ENDDO - CALL SPGRADY(IROMB,MAXWV,ENN1,EON,EONTOP, - & WAVE(KWS+1),W(1,KY),WTOP(1,KY)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE STATION FIELDS -C$OMP PARALLEL DO PRIVATE(KS,KY,KX,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,G,NK) - DO N=1,NMAX - IF(ABS(RLAT((N-1)*NR+1)).GE.89.9995) THEN - SLAT1=SIGN(1.,RLAT((N-1)*NR+1)) - CLAT1=0. - ELSE - SLAT1=SIN(PI/180*RLAT((N-1)*NR+1)) - CLAT1=COS(PI/180*RLAT((N-1)*NR+1)) - ENDIF - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,MDIM,2*MXTOP,2*KMAX, - & CLAT1,PLN,PLNTOP,MP,W,WTOP,F) - CALL SPGRADX(MAXWV,IDIM,KMAX,MP,CLAT1,F(1,1,1),F(1,1,2*KMAX+1)) - CALL SPFFTPT(MAXWV,1,IDIM,1,3*KMAX,RLON((N-1)*NR+1),F,G) - DO K=1,KMAX - KS=0*KMAX+K - KY=1*KMAX+K - KX=2*KMAX+K - NK=(N-1)*NG+(K-1)*KG+1 - GP(NK)=G(KS) - XP(NK)=G(KX) - YP(NK)=G(KY) - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgptv.f b/external/sp/v2.0.2/src/sptgptv.f deleted file mode 100644 index db4ddbd64..000000000 --- a/external/sp/v2.0.2/src/sptgptv.f +++ /dev/null @@ -1,130 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPTV(IROMB,MAXWV,KMAX,NMAX, - & KWSKIP,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WAVED,WAVEZ,UP,VP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPTV TRANSFORM SPECTRAL VECTOR TO STATION POINTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C TO SPECIFIED SETS OF STATION POINT VECTORS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND POINT FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER STATIONS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C 1999-08-18 IREDELL OPENMP DIRECTIVE TYPO FIXED -C 2003-06-30 IREDELL USE SPFFTPT -C -C USAGE: CALL SPTGPTV(IROMB,MAXWV,KMAX,NMAX, -C & KWSKIP,KGSKIP,NRSKIP,NGSKIP, -C & RLAT,RLON,WAVED,WAVEZ,UP,VP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS -C OUTPUT ARGUMENTS: -C UP - REAL (*) STATION POINT U-WIND SETS -C VP - REAL (*) STATION POINT V-WIND SETS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C SPFFTPT POINTWISE FOURIER TRANSFORM -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL RLAT(*),RLON(*),WAVED(*),WAVEZ(*),UP(*),VP(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - INTEGER MP(2*KMAX) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,2*KMAX) - REAL WTOP(2*(MAXWV+1),2*KMAX) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),PLNTOP(MAXWV+1) - REAL F(2*MAXWV+3,2,2*KMAX) - REAL G(2*KMAX) - PARAMETER(PI=3.14159265358979) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - MDIM=2*MX+1 - IDIM=2*MAXWV+3 - KW=KWSKIP - KG=KGSKIP - NR=NRSKIP - NG=NGSKIP - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=NMAX - IF(NR.EQ.0) NR=1 - IF(NG.EQ.0) NG=1 - MP=1 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE SPECTRAL WINDS -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - CALL SPDZ2UV(IROMB,MAXWV,ENN1,ELONN1,EON,EONTOP, - & WAVED(KWS+1),WAVEZ(KWS+1), - & W(1,K),W(1,KMAX+K),WTOP(1,K),WTOP(1,KMAX+K)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE STATION FIELDS -C$OMP PARALLEL DO PRIVATE(KU,KV,RADLAT,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,G,NK) - DO N=1,NMAX - RADLAT=PI/180*RLAT((N-1)*NR+1) - IF(RLAT((N-1)*NR+1).GE.89.9995) THEN - SLAT1=1. - CLAT1=0. - ELSEIF(RLAT((N-1)*NR+1).LE.-89.9995) THEN - SLAT1=-1. - CLAT1=0. - ELSE - SLAT1=SIN(RADLAT) - CLAT1=COS(RADLAT) - ENDIF - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,MDIM,2*MXTOP,2*KMAX, - & CLAT1,PLN,PLNTOP,MP,W,WTOP,F) - CALL SPFFTPT(MAXWV,1,2*MAXWV+3,1,2*KMAX,RLON((N-1)*NR+1),F,G) - DO K=1,KMAX - KU=K - KV=K+KMAX - NK=(N-1)*NG+(K-1)*KG+1 - UP(NK)=G(KU) - VP(NK)=G(KV) - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptgptvd.f b/external/sp/v2.0.2/src/sptgptvd.f deleted file mode 100644 index ec2326d99..000000000 --- a/external/sp/v2.0.2/src/sptgptvd.f +++ /dev/null @@ -1,168 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTGPTVD(IROMB,MAXWV,KMAX,NMAX, - & KWSKIP,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WAVED,WAVEZ, - & DP,ZP,UP,VP,UXP,VXP,UYP,VYP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTGPTVD TRANSFORM SPECTRAL VECTOR TO STATION POINTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C FROM SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C TO SPECIFIED SETS OF STATION POINT VECTORS AND THEIR -C GRADIENTS ON THE GLOBE. -C DP=(D(UP)/DLON+D(VP*CLAT)/DLAT)/(R*CLAT) -C ZP=(D(VP)/DLON-D(UP*CLAT)/DLAT)/(R*CLAT) -C UXP=D(UP*CLAT)/DLON/(R*CLAT) -C VXP=D(VP*CLAT)/DLON/(R*CLAT) -C UYP=D(UP*CLAT)/DLAT/R -C VYP=D(VP*CLAT)/DLAT/R -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE WAVE AND POINT FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER STATIONS. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C 1999-08-18 IREDELL OPENMP DIRECTIVE TYPO FIXED -C -C USAGE: CALL SPTGPTVD(IROMB,MAXWV,KMAX,NMAX, -C & KWSKIP,KGSKIP,NRSKIP,NGSKIP, -C & RLAT,RLON,WAVED,WAVEZ, -C & DP,ZP,UP,VP,UXP,VXP,UYP,VYP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS -C OUTPUT ARGUMENTS: -C DP - REAL (*) STATION POINT DIVERGENCE SETS -C ZP - REAL (*) STATION POINT VORTICITY SETS -C UP - REAL (*) STATION POINT U-WIND SETS -C VP - REAL (*) STATION POINT V-WIND SETS -C UXP - REAL (*) STATION POINT U-WIND X-GRADIENT SETS -C VXP - REAL (*) STATION POINT V-WIND X-GRADIENT SETS -C UYP - REAL (*) STATION POINT U-WIND Y-GRADIENT SETS -C VYP - REAL (*) STATION POINT V-WIND Y-GRADIENT SETS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C SPGRADX COMPUTE X-GRADIENT IN FOURIER SPACE -C SPFFTPT COMPUTE FOURIER TRANSFORM TO GRIDPOINTS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL RLAT(*),RLON(*),WAVED(*),WAVEZ(*) - REAL DP(*),ZP(*),UP(*),VP(*),UXP(*),VXP(*),UYP(*),VYP(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - INTEGER MP(4*KMAX) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2,4*KMAX) - REAL WTOP(2*(MAXWV+1),4*KMAX) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),PLNTOP(MAXWV+1) - REAL F(2*MAXWV+2,2,6*KMAX),G(6*KMAX) - PARAMETER(PI=3.14159265358979) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE PRELIMINARY CONSTANTS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - MDIM=2*MX - IDIM=2*MAXWV+2 - KW=KWSKIP - KG=KGSKIP - NR=NRSKIP - NG=NGSKIP - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=NMAX - IF(NR.EQ.0) NR=1 - IF(NG.EQ.0) NG=1 - MP(1:2*KMAX)=0 - MP(2*KMAX+1:4*KMAX)=1 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE SPECTRAL WINDS -C$OMP PARALLEL DO PRIVATE(KWS,KD,KZ,KU,KV) - DO K=1,KMAX - KWS=(K-1)*KW - KD=0*KMAX+K - KZ=1*KMAX+K - KU=2*KMAX+K - KV=3*KMAX+K - DO I=1,2*MX - W(I,KD)=WAVED(KWS+I) - W(I,KZ)=WAVEZ(KWS+I) - ENDDO - DO I=1,2*MXTOP - WTOP(I,KD)=0 - WTOP(I,KZ)=0 - ENDDO - CALL SPDZ2UV(IROMB,MAXWV,ENN1,ELONN1,EON,EONTOP, - & WAVED(KWS+1),WAVEZ(KWS+1), - & W(1,KU),W(1,KV),WTOP(1,KU),WTOP(1,KV)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CALCULATE STATION FIELDS -C$OMP PARALLEL DO PRIVATE(KD,KZ,KU,KV,KUX,KVX,SLAT1,CLAT1) -C$OMP& PRIVATE(PLN,PLNTOP,F,G,NK) - DO N=1,NMAX - KU=2*KMAX+1 - KUX=4*KMAX+1 - IF(ABS(RLAT((N-1)*NR+1)).GE.89.9995) THEN - SLAT1=SIGN(1.,RLAT((N-1)*NR+1)) - CLAT1=0. - ELSE - SLAT1=SIN(PI/180*RLAT((N-1)*NR+1)) - CLAT1=COS(PI/180*RLAT((N-1)*NR+1)) - ENDIF - CALL SPLEGEND(IROMB,MAXWV,SLAT1,CLAT1,EPS,EPSTOP, - & PLN,PLNTOP) - CALL SPSYNTH(IROMB,MAXWV,2*MAXWV,IDIM,MDIM,2*MXTOP,4*KMAX, - & CLAT1,PLN,PLNTOP,MP,W,WTOP,F) - CALL SPGRADX(MAXWV,IDIM,2*KMAX,MP(2*KMAX+1),CLAT1, - & F(1,1,2*KMAX+1),F(1,1,4*KMAX+1)) - CALL SPFFTPT(MAXWV,1,IDIM,1,6*KMAX,RLON((N-1)*NR+1),F,G) - DO K=1,KMAX - KD=0*KMAX+K - KZ=1*KMAX+K - KU=2*KMAX+K - KV=3*KMAX+K - KUX=4*KMAX+K - KVX=5*KMAX+K - NK=(N-1)*NG+(K-1)*KG+1 - DP(NK)=G(KD) - ZP(NK)=G(KZ) - UP(NK)=G(KU) - VP(NK)=G(KV) - UXP(NK)=G(KUX) - VXP(NK)=G(KVX) - UYP(NK)=G(KVX)-CLAT1*G(KZ) - VYP(NK)=CLAT1*G(KD)-G(KUX) - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptran.f b/external/sp/v2.0.2/src/sptran.f deleted file mode 100644 index f447274f4..000000000 --- a/external/sp/v2.0.2/src/sptran.f +++ /dev/null @@ -1,138 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRAN(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, - & JBEG,JEND,JCPU, - & WAVE,GRIDN,GRIDS,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C AND FIELDS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C TRANSFORMS ARE DONE IN LATITUDE PAIRS FOR EFFICIENCY; -C THUS GRID ARRAYS FOR EACH HEMISPHERE MUST BE PASSED. -C IF SO REQUESTED, JUST A SUBSET OF THE LATITUDE PAIRS -C MAY BE TRANSFORMED IN EACH INVOCATION OF THE SUBPROGRAM. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER LATITUDE EXCEPT -C THE TRANSFORM FROM FOURIER TO SPECTRAL IS MULTIPROCESSED -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL GENERIC FFT USED -C OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTRAN(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, -C & JBEG,JEND,JCPU, -C & WAVE,GRIDN,GRIDS,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C ISKIP - INTEGER SKIP NUMBER BETWEEN LONGITUDES -C (DEFAULTS TO 1 IF ISKIP=0) -C JNSKIP - INTEGER SKIP NUMBER BETWEEN N.H. LATITUDES FROM NORTH -C (DEFAULTS TO IMAX IF JNSKIP=0) -C JSSKIP - INTEGER SKIP NUMBER BETWEEN S.H. LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAX IF JSSKIP=0) -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO IMAX*JMAX IF KGSKIP=0) -C JBEG - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C (DEFAULTS TO 1 IF JBEG=0) -C (IF JBEG=0 AND IDIR<0, WAVE IS ZEROED BEFORE TRANSFORM) -C JEND - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C (DEFAULTS TO (JMAX+1)/2 IF JEND=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C WAVE - REAL (*) WAVE FIELDS IF IDIR>0 -C GRIDN - REAL (*) N.H. GRID FIELDS (STARTING AT JBEG) IF IDIR<0 -C GRIDS - REAL (*) S.H. GRID FIELDS (STARTING AT JBEG) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (*) WAVE FIELDS IF IDIR<0 -C GRIDN - REAL (*) N.H. GRID FIELDS (STARTING AT JBEG) IF IDIR>0 -C GRIDS - REAL (*) S.H. GRID FIELDS (STARTING AT JBEG) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRANF PERFORM A SCALAR SPHERICAL TRANSFORM -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE(*),GRIDN(*),GRIDS(*) -!==EM== integer JC, JCPU -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -!==EM== -! print *, "jjjjjjjcccccccccc from SPTRAN- before NCPUS", JC - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - IP=IPRIME - IS=ISKIP - JN=JNSKIP - JS=JSSKIP - KW=KWSKIP - KG=KGSKIP - JB=JBEG - JE=JEND - JC=JCPU - IF(IP.EQ.0) IP=1 - IF(IS.EQ.0) IS=1 - IF(JN.EQ.0) JN=IMAX - IF(JS.EQ.0) JS=-JN - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=IMAX*JMAX - IF(JB.EQ.0) JB=1 - IF(JE.EQ.0) JE=(JMAX+1)/2 - IF(JC.EQ.0) JC=NCPUS() -! JC=NCPUS() -!==EM== -! print *, "jjjjjjjjjjjjjjjjjjjjcccccccccc from SPTRAN", JC -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(IDIR.LT.0.AND.JBEG.EQ.0) THEN - DO K=1,KMAX - KWS=(K-1)*KW - WAVE(KWS+1:KWS+2*MX)=0 - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -!==EM== -! print *, "jjjjjjjcccccccccc from SPTRANF- before NCPUS", JC - CALL SPTRANF(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IP,IS,JN,JS,KW,KG,JB,JE,JC, - & WAVE,GRIDN,GRIDS,IDIR) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrand.f b/external/sp/v2.0.2/src/sptrand.f deleted file mode 100644 index 323815b93..000000000 --- a/external/sp/v2.0.2/src/sptrand.f +++ /dev/null @@ -1,164 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRAND(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, - & JBEG,JEND,JCPU, - & WAVE,GRIDMN,GRIDXN,GRIDXS,GRIDYN,GRIDYS,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRAND PERFORM A GRADIENT SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF SCALAR FIELDS -C AND THEIR MEANS AND GRADIENTS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C TRANSFORMS ARE DONE IN LATITUDE PAIRS FOR EFFICIENCY; -C THUS GRID ARRAYS FOR EACH HEMISPHERE MUST BE PASSED. -C IF SO REQUESTED, JUST A SUBSET OF THE LATITUDE PAIRS -C MAY BE TRANSFORMED IN EACH INVOCATION OF THE SUBPROGRAM. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER LATITUDE EXCEPT -C THE TRANSFORM FROM FOURIER TO SPECTRAL IS MULTIPROCESSED -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTRAND(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, -C & JBEG,JEND,JCPU, -C & WAVE,GRIDMN,GRIDXN,GRIDXS,GRIDYN,GRIDYS,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C ISKIP - INTEGER SKIP NUMBER BETWEEN LONGITUDES -C (DEFAULTS TO 1 IF ISKIP=0) -C JNSKIP - INTEGER SKIP NUMBER BETWEEN N.H. LATITUDES FROM NORTH -C (DEFAULTS TO IMAX IF JNSKIP=0) -C JSSKIP - INTEGER SKIP NUMBER BETWEEN S.H. LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAX IF JSSKIP=0) -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO IMAX*JMAX IF KGSKIP=0) -C JBEG - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C (DEFAULTS TO 1 IF JBEG=0) -C (IF JBEG=0 AND IDIR<0, WAVE IS ZEROED BEFORE TRANSFORM) -C JEND - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C (DEFAULTS TO (JMAX+1)/2 IF JEND=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C WAVE - REAL (*) WAVE FIELDS IF IDIR>0 -C GRIDMN - REAL (KMAX) GLOBAL MEANS IF IDIR<0 -C GRIDXN - REAL (*) N.H. X-GRADIENTS (STARTING AT JBEG) IF IDIR<0 -C GRIDXS - REAL (*) S.H. X-GRADIENTS (STARTING AT JBEG) IF IDIR<0 -C GRIDYN - REAL (*) N.H. Y-GRADIENTS (STARTING AT JBEG) IF IDIR<0 -C GRIDYS - REAL (*) S.H. Y-GRADIENTS (STARTING AT JBEG) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (*) WAVE FIELDS IF IDIR<0 -C GRIDMN - REAL (KMAX) GLOBAL MEANS IF IDIR>0 -C GRIDXN - REAL (*) N.H. X-GRADIENTS (STARTING AT JBEG) IF IDIR>0 -C GRIDXS - REAL (*) S.H. X-GRADIENTS (STARTING AT JBEG) IF IDIR>0 -C [GRIDX=(D(WAVE)/DLAM)/(CLAT*RERTH)] -C GRIDYN - REAL (*) N.H. Y-GRADIENTS (STARTING AT JBEG) IF IDIR>0 -C GRIDYS - REAL (*) S.H. Y-GRADIENTS (STARTING AT JBEG) IF IDIR>0 -C [GRIDY=(D(WAVE)/DPHI)/RERTH] -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE(*),GRIDMN(KMAX),GRIDXN(*),GRIDXS(*),GRIDYN(*),GRIDYS(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL WD((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL WZ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SET PARAMETERS - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - KW=KWSKIP - IF(KW.EQ.0) KW=2*MX -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO GRID - IF(IDIR.GT.0) THEN -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - GRIDMN(K)=WAVE(KWS+1)/SQRT(2.) - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WAVE(KWS+1),WD(1,K),1) - WZ(1:2*MX,K)=0. - ENDDO - CALL SPTRANV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IPRIME,ISKIP,JNSKIP,JSSKIP,MDIM,KGSKIP, - & JBEG,JEND,JCPU, - & WD,WZ,GRIDXN,GRIDXS,GRIDYN,GRIDYS,IDIR) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM GRID TO WAVE - ELSE -C$OMP PARALLEL DO - DO K=1,KMAX - WD(1:2*MX,K)=0. - WZ(1:2*MX,K)=0. - ENDDO - CALL SPTRANV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IPRIME,ISKIP,JNSKIP,JSSKIP,MDIM,KGSKIP, - & JBEG,JEND,JCPU, - & WD,WZ,GRIDXN,GRIDXS,GRIDYN,GRIDYS,IDIR) - IF(JBEG.EQ.0) THEN -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WAVE(KWS+1),WD(1,K),-1) - WAVE(KWS+1)=GRIDMN(K)*SQRT(2.) - ENDDO - ELSE -C$OMP PARALLEL DO PRIVATE(KWS) - DO K=1,KMAX - KWS=(K-1)*KW - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WZ(1,K),WD(1,K),-1) - WAVE(KWS+1:KWS+2*MX)=WAVE(KWS+1:KWS+2*MX)+WZ(1:2*MX,K) - WAVE(KWS+1)=GRIDMN(K)*SQRT(2.) - ENDDO - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptranf.f b/external/sp/v2.0.2/src/sptranf.f deleted file mode 100644 index 46d84b1ed..000000000 --- a/external/sp/v2.0.2/src/sptranf.f +++ /dev/null @@ -1,176 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRANF(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IP,IS,JN,JS,KW,KG,JB,JE,JC, - & WAVE,GRIDN,GRIDS,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF SCALAR QUANTITIES -C AND FIELDS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C TRANSFORMS ARE DONE IN LATITUDE PAIRS FOR EFFICIENCY; -C THUS GRID ARRAYS FOR EACH HEMISPHERE MUST BE PASSED. -C IF SO REQUESTED, JUST A SUBSET OF THE LATITUDE PAIRS -C MAY BE TRANSFORMED IN EACH INVOCATION OF THE SUBPROGRAM. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER LATITUDE EXCEPT -C THE TRANSFORM FROM FOURIER TO SPECTRAL IS MULTIPROCESSED -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL GENERIC FFT USED -C OPENMP DIRECTIVES INSERTED -C 2013-01-16 IREDELL & -C MIRVIS :: -C FIXING AFFT NEGATIVE SHARING EFFECT DURING -C OMP LOOPS BY CREATING TMP AFFT COPY (AFFT_TMP) -C TO BE PRIVATE DURING OMP LOOP THREADING -C -C USAGE: CALL SPTRANF(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & IP,IS,JN,JS,KW,KG,JB,JE,JC, -C & WAVE,GRIDN,GRIDS,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IP - INTEGER LONGITUDE INDEX FOR THE PRIME MERIDIAN -C IS - INTEGER SKIP NUMBER BETWEEN LONGITUDES -C JN - INTEGER SKIP NUMBER BETWEEN N.H. LATITUDES FROM NORTH -C JS - INTEGER SKIP NUMBER BETWEEN S.H. LATITUDES FROM SOUTH -C KW - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C KG - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C JB - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C JE - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C JC - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C WAVE - REAL (*) WAVE FIELDS IF IDIR>0 -C GRIDN - REAL (*) N.H. GRID FIELDS (STARTING AT JB) IF IDIR<0 -C GRIDS - REAL (*) S.H. GRID FIELDS (STARTING AT JB) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVE - REAL (*) WAVE FIELDS IF IDIR<0 -C GRIDN - REAL (*) N.H. GRID FIELDS (STARTING AT JB) IF IDIR>0 -C GRIDS - REAL (*) S.H. GRID FIELDS (STARTING AT JB) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRANF0 SPTRANF SPECTRAL INITIALIZATION -C SPTRANF1 SPTRANF SPECTRAL TRANSFORM -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVE(*),GRIDN(*),GRIDS(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL(8) AFFT(50000+4*IMAX), AFFT_TMP(50000+4*IMAX) - REAL CLAT(JB:JE),SLAT(JB:JE),WLAT(JB:JE) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2,JB:JE) - REAL PLNTOP(MAXWV+1,JB:JE) - REAL WTOP(2*(MAXWV+1)) - REAL G(IMAX,2) -! write(0,*) 'sptranf top' -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SET PARAMETERS - MP=0 - CALL SPTRANF0(IROMB,MAXWV,IDRT,IMAX,JMAX,JB,JE, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT,CLAT,SLAT,WLAT,PLN,PLNTOP) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO GRID - IF(IDIR.GT.0) THEN -C$OMP PARALLEL DO PRIVATE(AFFT_TMP,KWS,WTOP,G,IJKN,IJKS) - DO K=1,KMAX - AFFT_TMP=AFFT - KWS=(K-1)*KW - WTOP=0 - DO J=JB,JE - CALL SPTRANF1(IROMB,MAXWV,IDRT,IMAX,JMAX,J,J, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT_TMP,CLAT(J),SLAT(J),WLAT(J), - & PLN(1,J),PLNTOP(1,J),MP, - & WAVE(KWS+1),WTOP,G,IDIR) - IF(IP.EQ.1.AND.IS.EQ.1) THEN - DO I=1,IMAX - IJKN=I+(J-JB)*JN+(K-1)*KG - IJKS=I+(J-JB)*JS+(K-1)*KG - GRIDN(IJKN)=G(I,1) - GRIDS(IJKS)=G(I,2) - ENDDO - ELSE - DO I=1,IMAX - IJKN=MOD(I+IP-2,IMAX)*IS+(J-JB)*JN+(K-1)*KG+1 - IJKS=MOD(I+IP-2,IMAX)*IS+(J-JB)*JS+(K-1)*KG+1 - GRIDN(IJKN)=G(I,1) - GRIDS(IJKS)=G(I,2) - ENDDO - ENDIF - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM GRID TO WAVE - ELSE -C$OMP PARALLEL DO PRIVATE(AFFT_TMP,KWS,WTOP,G,IJKN,IJKS) - DO K=1,KMAX - AFFT_TMP=AFFT - KWS=(K-1)*KW - WTOP=0 - DO J=JB,JE - IF(WLAT(J).GT.0.) THEN - IF(IP.EQ.1.AND.IS.EQ.1) THEN - DO I=1,IMAX - IJKN=I+(J-JB)*JN+(K-1)*KG - IJKS=I+(J-JB)*JS+(K-1)*KG - G(I,1)=GRIDN(IJKN) - G(I,2)=GRIDS(IJKS) - ENDDO - ELSE - DO I=1,IMAX - IJKN=MOD(I+IP-2,IMAX)*IS+(J-JB)*JN+(K-1)*KG+1 - IJKS=MOD(I+IP-2,IMAX)*IS+(J-JB)*JS+(K-1)*KG+1 - G(I,1)=GRIDN(IJKN) - G(I,2)=GRIDS(IJKS) - ENDDO - ENDIF - CALL SPTRANF1(IROMB,MAXWV,IDRT,IMAX,JMAX,J,J, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT_TMP,CLAT(J),SLAT(J),WLAT(J), - & PLN(1,J),PLNTOP(1,J),MP, - & WAVE(KWS+1),WTOP,G,IDIR) - ENDIF - ENDDO - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptranf0.f b/external/sp/v2.0.2/src/sptranf0.f deleted file mode 100644 index 037d819b4..000000000 --- a/external/sp/v2.0.2/src/sptranf0.f +++ /dev/null @@ -1,83 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRANF0(IROMB,MAXWV,IDRT,IMAX,JMAX,JB,JE, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT,CLAT,SLAT,WLAT,PLN,PLNTOP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRANF0 SPTRANF SPECTRAL INITIALIZATION -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS AN INITIALIZATION FOR -C SUBPROGRAM SPTRANF. USE THIS SUBPROGRAM OUTSIDE -C THE SPTRANF FAMILY CONTEXT AT YOUR OWN RISK. -C -C PROGRAM HISTORY LOG: -C 1998-12-15 IREDELL -C -C USAGE: CALL SPTRANF0(IROMB,MAXWV,IDRT,IMAX,JMAX,JB,JE, -C & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, -C & AFFT,CLAT,SLAT,WLAT,PLN,PLNTOP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES -C JMAX - INTEGER NUMBER OF LATITUDES -C JB - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C JE - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C OUTPUT ARGUMENTS: -C EPS - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EPSTOP - REAL (MAXWV+1) -C ENN1 - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C ELONN1 - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EON - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EONTOP - REAL (MAXWV+1) -C AFFT - REAL(8) (50000+4*IMAX) AUXILIARY ARRAY IF IDIR=0 -C CLAT - REAL (JB:JE) COSINES OF LATITUDE -C SLAT - REAL (JB:JE) SINES OF LATITUDE -C WLAT - REAL (JB:JE) GAUSSIAN WEIGHTS -C PLN - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2,JB:JE) -C LEGENDRE POLYNOMIALS -C PLNTOP - REAL (MAXWV+1,JB:JE) LEGENDRE POLYNOMIAL OVER TOP -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPFFTE PERFORM FAST FOURIER TRANSFORM -C SPLAT COMPUTE LATITUDE FUNCTIONS -C SPLEGEND COMPUTE LEGENDRE POLYNOMIALS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL(8) AFFT(50000+4*IMAX) - REAL CLAT(JB:JE),SLAT(JB:JE),WLAT(JB:JE) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2,JB:JE) - REAL PLNTOP(MAXWV+1,JB:JE) - REAL SLATX(JMAX),WLATX(JMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - CALL SPFFTE(IMAX,(IMAX+2)/2,IMAX,2,0.,0.,0,AFFT) - CALL SPLAT(IDRT,JMAX,SLATX,WLATX) - JHE=(JMAX+1)/2 - IF(JHE.GT.JMAX/2) WLATX(JHE)=WLATX(JHE)/2 - DO J=JB,JE - CLAT(J)=SQRT(1.-SLATX(J)**2) - SLAT(J)=SLATX(J) - WLAT(J)=WLATX(J) - ENDDO -C$OMP PARALLEL DO - DO J=JB,JE - CALL SPLEGEND(IROMB,MAXWV,SLAT(J),CLAT(J),EPS,EPSTOP, - & PLN(1,J),PLNTOP(1,J)) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptranf1.f b/external/sp/v2.0.2/src/sptranf1.f deleted file mode 100644 index 2c479ef06..000000000 --- a/external/sp/v2.0.2/src/sptranf1.f +++ /dev/null @@ -1,99 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRANF1(IROMB,MAXWV,IDRT,IMAX,JMAX,JB,JE, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT,CLAT,SLAT,WLAT,PLN,PLNTOP,MP, - & W,WTOP,G,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRANF1 SPTRANF SPECTRAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS AN SINGLE LATITUDE TRANSFORM FOR -C SUBPROGRAM SPTRANF. USE THIS SUBPROGRAM OUTSIDE -C THE SPTRANF FAMILY CONTEXT AT YOUR OWN RISK. -C -C PROGRAM HISTORY LOG: -C 1998-12-15 IREDELL -C -C USAGE: CALL SPTRANF1(IROMB,MAXWV,IDRT,IMAX,JMAX,JB,JE, -C & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, -C & AFFT,CLAT,SLAT,WLAT,PLN,PLNTOP,MP, -C & W,WTOP,G,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES -C JMAX - INTEGER NUMBER OF LATITUDES -C JB - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C JE - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C EPS - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EPSTOP - REAL (MAXWV+1) -C ENN1 - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C ELONN1 - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EON - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EONTOP - REAL (MAXWV+1) -C CLAT - REAL (JB:JE) COSINES OF LATITUDE -C SLAT - REAL (JB:JE) SINES OF LATITUDE -C WLAT - REAL (JB:JE) GAUSSIAN WEIGHTS -C AFFT - REAL(8) (50000+4*IMAX) AUXILIARY ARRAY IF IDIR=0 -C PLN - REAL ((M+1)*((I+1)*M+2)/2,JB:JE) LEGENDRE POLYNOMIALS -C PLNTOP - REAL (M+1,JB:JE) LEGENDRE POLYNOMIAL OVER TOP -C MP - INTEGER IDENTIFIER (0 FOR SCALAR, 1 FOR VECTOR) -C W - REAL (*) WAVE FIELD IF IDIR>0 -C WTOP - REAL (*) WAVE FIELD OVER TOP IF IDIR>0 -C G - REAL (IMAX,2,JB:JE) GRID FIELD IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C W - REAL (*) WAVE FIELD IF IDIR<0 -C WTOP - REAL (*) WAVE FIELD OVER TOP IF IDIR<0 -C G - REAL (IMAX,2,JB:JE) GRID FIELD IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPSYNTH SYNTHESIZE FOURIER FROM SPECTRAL -C SPANALY ANALYZE SPECTRAL FROM FOURIER -C SPFFTE PERFORM FAST FOURIER TRANSFORM -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL(8) AFFT(50000+4*IMAX) - REAL CLAT(JB:JE),SLAT(JB:JE),WLAT(JB:JE) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2,JB:JE) - REAL PLNTOP(MAXWV+1,JB:JE) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)) - REAL WTOP(2*(MAXWV+1)) - REAL G(IMAX,2,JB:JE) - REAL F(IMAX+2,2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! write(0,*) 'sptranf1 top' - KW=(MAXWV+1)*((IROMB+1)*MAXWV+2) - KWTOP=2*(MAXWV+1) - IF(IDIR.GT.0) THEN - DO J=JB,JE - CALL SPSYNTH(IROMB,MAXWV,IMAX,IMAX+2,KW,KWTOP,1, - & CLAT(J),PLN(1,J),PLNTOP(1,J),MP, - & W,WTOP,F) - CALL SPFFTE(IMAX,(IMAX+2)/2,IMAX,2,F,G(1,1,J),+1,AFFT) - ENDDO - ELSE - DO J=JB,JE - CALL SPFFTE(IMAX,(IMAX+2)/2,IMAX,2,F,G(1,1,J),-1,AFFT) - CALL SPANALY(IROMB,MAXWV,IMAX,IMAX+2,KW,KWTOP,1, - & WLAT(J),CLAT(J),PLN(1,J),PLNTOP(1,J),MP, - & F,W,WTOP) - ENDDO -! write(0,*) 'sptranf1 end' - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptranfv.f b/external/sp/v2.0.2/src/sptranfv.f deleted file mode 100644 index 6bceb1b78..000000000 --- a/external/sp/v2.0.2/src/sptranfv.f +++ /dev/null @@ -1,215 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRANFV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IP,IS,JN,JS,KW,KG,JB,JE,JC, - & WAVED,WAVEZ,GRIDUN,GRIDUS,GRIDVN,GRIDVS,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRANFV PERFORM A VECTOR SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C AND VECTOR FIELDS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C TRANSFORMS ARE DONE IN LATITUDE PAIRS FOR EFFICIENCY; -C THUS GRID ARRAYS FOR EACH HEMISPHERE MUST BE PASSED. -C IF SO REQUESTED, JUST A SUBSET OF THE LATITUDE PAIRS -C MAY BE TRANSFORMED IN EACH INVOCATION OF THE SUBPROGRAM. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER LATITUDE EXCEPT -C THE TRANSFORM FROM FOURIER TO SPECTRAL IS MULTIPROCESSED -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL GENERIC FFT USED -C OPENMP DIRECTIVES INSERTED -C 2013-01-16 IREDELL & -C MIRVIS :: -C FIXING AFFT NEGATIVE SHARING EFFECT DURING -C OMP LOOPS BY CREATING TMP AFFT COPY (AFFT_TMP) -C TO BE PRIVATE DURING OMP LOOP THREADING -C -C USAGE: CALL SPTRANFV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & IP,IS,JN,JS,KW,KG,JB,JE,JC, -C & WAVED,WAVEZ,GRIDUN,GRIDUS,GRIDVN,GRIDVS,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IP - INTEGER LONGITUDE INDEX FOR THE PRIME MERIDIAN -C IS - INTEGER SKIP NUMBER BETWEEN LONGITUDES -C JN - INTEGER SKIP NUMBER BETWEEN N.H. LATITUDES FROM NORTH -C JS - INTEGER SKIP NUMBER BETWEEN S.H. LATITUDES FROM SOUTH -C KW - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C KG - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C JB - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C JE - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C JC - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS IF IDIR>0 -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS IF IDIR>0 -C GRIDUN - REAL (*) N.H. GRID U-WINDS (STARTING AT JB) IF IDIR<0 -C GRIDUS - REAL (*) S.H. GRID U-WINDS (STARTING AT JB) IF IDIR<0 -C GRIDVN - REAL (*) N.H. GRID V-WINDS (STARTING AT JB) IF IDIR<0 -C GRIDVS - REAL (*) S.H. GRID V-WINDS (STARTING AT JB) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS IF IDIR<0 -C [WAVED=(D(GRIDU)/DLAM+D(CLAT*GRIDV)/DPHI)/(CLAT*RERTH)] -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS IF IDIR<0 -C [WAVEZ=(D(GRIDV)/DLAM-D(CLAT*GRIDU)/DPHI)/(CLAT*RERTH)] -C GRIDUN - REAL (*) N.H. GRID U-WINDS (STARTING AT JB) IF IDIR>0 -C GRIDUS - REAL (*) S.H. GRID U-WINDS (STARTING AT JB) IF IDIR>0 -C GRIDVN - REAL (*) N.H. GRID V-WINDS (STARTING AT JB) IF IDIR>0 -C GRIDVS - REAL (*) S.H. GRID V-WINDS (STARTING AT JB) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRANF0 SPTRANF SPECTRAL INITIALIZATION -C SPTRANF1 SPTRANF SPECTRAL TRANSFORM -C SPDZ2UV COMPUTE WINDS FROM DIVERGENCE AND VORTICITY -C SPUV2DZ COMPUTE DIVERGENCE AND VORTICITY FROM WINDS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVED(*),WAVEZ(*),GRIDUN(*),GRIDUS(*),GRIDVN(*),GRIDVS(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL(8) AFFT(50000+4*IMAX), AFFT_TMP(50000+4*IMAX) - REAL CLAT(JB:JE),SLAT(JB:JE),WLAT(JB:JE) - REAL PLN((MAXWV+1)*((IROMB+1)*MAXWV+2)/2,JB:JE) - REAL PLNTOP(MAXWV+1,JB:JE) - INTEGER MP(2) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2,2) - REAL WTOP(2*(MAXWV+1),2) - REAL G(IMAX,2,2) - REAL WINC((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2,2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SET PARAMETERS - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MP=1 - CALL SPTRANF0(IROMB,MAXWV,IDRT,IMAX,JMAX,JB,JE, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT,CLAT,SLAT,WLAT,PLN,PLNTOP) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO GRID - IF(IDIR.GT.0) THEN -C$OMP PARALLEL DO PRIVATE(AFFT_TMP,KWS,W,WTOP,G,IJKN,IJKS) - DO K=1,KMAX - AFFT_TMP=AFFT - KWS=(K-1)*KW - CALL SPDZ2UV(IROMB,MAXWV,ENN1,ELONN1,EON,EONTOP, - & WAVED(KWS+1),WAVEZ(KWS+1), - & W(1,1),W(1,2),WTOP(1,1),WTOP(1,2)) - DO J=JB,JE - CALL SPTRANF1(IROMB,MAXWV,IDRT,IMAX,JMAX,J,J, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT_TMP,CLAT(J),SLAT(J),WLAT(J), - & PLN(1,J),PLNTOP(1,J),MP, - & W(1,1),WTOP(1,1),G(1,1,1),IDIR) - CALL SPTRANF1(IROMB,MAXWV,IDRT,IMAX,JMAX,J,J, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT_TMP,CLAT(J),SLAT(J),WLAT(J), - & PLN(1,J),PLNTOP(1,J),MP, - & W(1,2),WTOP(1,2),G(1,1,2),IDIR) - IF(IP.EQ.1.AND.IS.EQ.1) THEN - DO I=1,IMAX - IJKN=I+(J-JB)*JN+(K-1)*KG - IJKS=I+(J-JB)*JS+(K-1)*KG - GRIDUN(IJKN)=G(I,1,1) - GRIDUS(IJKS)=G(I,2,1) - GRIDVN(IJKN)=G(I,1,2) - GRIDVS(IJKS)=G(I,2,2) - ENDDO - ELSE - DO I=1,IMAX - IJKN=MOD(I+IP-2,IMAX)*IS+(J-JB)*JN+(K-1)*KG+1 - IJKS=MOD(I+IP-2,IMAX)*IS+(J-JB)*JS+(K-1)*KG+1 - GRIDUN(IJKN)=G(I,1,1) - GRIDUS(IJKS)=G(I,2,1) - GRIDVN(IJKN)=G(I,1,2) - GRIDVS(IJKS)=G(I,2,2) - ENDDO - ENDIF - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM GRID TO WAVE - ELSE -C$OMP PARALLEL DO PRIVATE(AFFT_TMP,KWS,W,WTOP,G,IJKN,IJKS,WINC) - DO K=1,KMAX - AFFT_TMP=AFFT - KWS=(K-1)*KW - W=0 - WTOP=0 - DO J=JB,JE - IF(WLAT(J).GT.0.) THEN - IF(IP.EQ.1.AND.IS.EQ.1) THEN - DO I=1,IMAX - IJKN=I+(J-JB)*JN+(K-1)*KG - IJKS=I+(J-JB)*JS+(K-1)*KG - G(I,1,1)=GRIDUN(IJKN)/CLAT(J)**2 - G(I,2,1)=GRIDUS(IJKS)/CLAT(J)**2 - G(I,1,2)=GRIDVN(IJKN)/CLAT(J)**2 - G(I,2,2)=GRIDVS(IJKS)/CLAT(J)**2 - ENDDO - ELSE - DO I=1,IMAX - IJKN=MOD(I+IP-2,IMAX)*IS+(J-JB)*JN+(K-1)*KG+1 - IJKS=MOD(I+IP-2,IMAX)*IS+(J-JB)*JS+(K-1)*KG+1 - G(I,1,1)=GRIDUN(IJKN)/CLAT(J)**2 - G(I,2,1)=GRIDUS(IJKS)/CLAT(J)**2 - G(I,1,2)=GRIDVN(IJKN)/CLAT(J)**2 - G(I,2,2)=GRIDVS(IJKS)/CLAT(J)**2 - ENDDO - ENDIF - CALL SPTRANF1(IROMB,MAXWV,IDRT,IMAX,JMAX,J,J, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT_TMP,CLAT(J),SLAT(J),WLAT(J), - & PLN(1,J),PLNTOP(1,J),MP, - & W(1,1),WTOP(1,1),G(1,1,1),IDIR) - CALL SPTRANF1(IROMB,MAXWV,IDRT,IMAX,JMAX,J,J, - & EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP, - & AFFT_TMP,CLAT(J),SLAT(J),WLAT(J), - & PLN(1,J),PLNTOP(1,J),MP, - & W(1,2),WTOP(1,2),G(1,1,2),IDIR) - ENDIF - ENDDO - CALL SPUV2DZ(IROMB,MAXWV,ENN1,ELONN1,EON,EONTOP, - & W(1,1),W(1,2),WTOP(1,1),WTOP(1,2), - & WINC(1,1),WINC(1,2)) - WAVED(KWS+1:KWS+2*MX)=WAVED(KWS+1:KWS+2*MX)+WINC(1:2*MX,1) - WAVEZ(KWS+1:KWS+2*MX)=WAVEZ(KWS+1:KWS+2*MX)+WINC(1:2*MX,2) - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptranv.f b/external/sp/v2.0.2/src/sptranv.f deleted file mode 100644 index f4cd073c8..000000000 --- a/external/sp/v2.0.2/src/sptranv.f +++ /dev/null @@ -1,139 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRANV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, - & JBEG,JEND,JCPU, - & WAVED,WAVEZ,GRIDUN,GRIDUS,GRIDVN,GRIDVS,IDIR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM PERFORMS A SPHERICAL TRANSFORM -C BETWEEN SPECTRAL COEFFICIENTS OF DIVERGENCES AND CURLS -C AND VECTOR FIELDS ON A GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE WAVE AND GRID FIELDS MAY HAVE GENERAL INDEXING, -C BUT EACH WAVE FIELD IS IN SEQUENTIAL 'IBM ORDER', -C I.E. WITH ZONAL WAVENUMBER AS THE SLOWER INDEX. -C TRANSFORMS ARE DONE IN LATITUDE PAIRS FOR EFFICIENCY; -C THUS GRID ARRAYS FOR EACH HEMISPHERE MUST BE PASSED. -C IF SO REQUESTED, JUST A SUBSET OF THE LATITUDE PAIRS -C MAY BE TRANSFORMED IN EACH INVOCATION OF THE SUBPROGRAM. -C THE TRANSFORMS ARE ALL MULTIPROCESSED OVER LATITUDE EXCEPT -C THE TRANSFORM FROM FOURIER TO SPECTRAL IS MULTIPROCESSED -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL GENERIC FFT USED -C OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTRANV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, -C & IPRIME,ISKIP,JNSKIP,JSSKIP,KWSKIP,KGSKIP, -C & JBEG,JEND,JCPU, -C & WAVED,WAVEZ,GRIDUN,GRIDUS,GRIDVN,GRIDVS,IDIR) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRT - INTEGER GRID IDENTIFIER -C (IDRT=4 FOR GAUSSIAN GRID, -C IDRT=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRT=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAX - INTEGER EVEN NUMBER OF LONGITUDES. -C JMAX - INTEGER NUMBER OF LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C ISKIP - INTEGER SKIP NUMBER BETWEEN LONGITUDES -C (DEFAULTS TO 1 IF ISKIP=0) -C JNSKIP - INTEGER SKIP NUMBER BETWEEN N.H. LATITUDES FROM NORTH -C (DEFAULTS TO IMAX IF JNSKIP=0) -C JSSKIP - INTEGER SKIP NUMBER BETWEEN S.H. LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAX IF JSSKIP=0) -C KWSKIP - INTEGER SKIP NUMBER BETWEEN WAVE FIELDS -C (DEFAULTS TO (MAXWV+1)*((IROMB+1)*MAXWV+2) IF KWSKIP=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO IMAX*JMAX IF KGSKIP=0) -C JBEG - INTEGER LATITUDE INDEX (FROM POLE) TO BEGIN TRANSFORM -C (DEFAULTS TO 1 IF JBEG=0) -C (IF JBEG=0 AND IDIR<0, WAVE IS ZEROED BEFORE TRANSFORM) -C JEND - INTEGER LATITUDE INDEX (FROM POLE) TO END TRANSFORM -C (DEFAULTS TO (JMAX+1)/2 IF JEND=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS IF IDIR>0 -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS IF IDIR>0 -C GRIDUN - REAL (*) N.H. GRID U-WINDS (STARTING AT JBEG) IF IDIR<0 -C GRIDUS - REAL (*) S.H. GRID U-WINDS (STARTING AT JBEG) IF IDIR<0 -C GRIDVN - REAL (*) N.H. GRID V-WINDS (STARTING AT JBEG) IF IDIR<0 -C GRIDVS - REAL (*) S.H. GRID V-WINDS (STARTING AT JBEG) IF IDIR<0 -C IDIR - INTEGER TRANSFORM FLAG -C (IDIR>0 FOR WAVE TO GRID, IDIR<0 FOR GRID TO WAVE) -C OUTPUT ARGUMENTS: -C WAVED - REAL (*) WAVE DIVERGENCE FIELDS IF IDIR<0 -C [WAVED=(D(GRIDU)/DLAM+D(CLAT*GRIDV)/DPHI)/(CLAT*RERTH)] -C WAVEZ - REAL (*) WAVE VORTICITY FIELDS IF IDIR<0 -C [WAVEZ=(D(GRIDV)/DLAM-D(CLAT*GRIDU)/DPHI)/(CLAT*RERTH)] -C GRIDUN - REAL (*) N.H. GRID U-WINDS (STARTING AT JBEG) IF IDIR>0 -C GRIDUS - REAL (*) S.H. GRID U-WINDS (STARTING AT JBEG) IF IDIR>0 -C GRIDVN - REAL (*) N.H. GRID V-WINDS (STARTING AT JBEG) IF IDIR>0 -C GRIDVS - REAL (*) S.H. GRID V-WINDS (STARTING AT JBEG) IF IDIR>0 -C -C SUBPROGRAMS CALLED: -C SPTRANFV PERFORM A VECTOR SPHERICAL TRANSFORM -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL WAVED(*),WAVEZ(*),GRIDUN(*),GRIDUS(*),GRIDVN(*),GRIDVS(*) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - IP=IPRIME - IS=ISKIP - JN=JNSKIP - JS=JSSKIP - KW=KWSKIP - KG=KGSKIP - JB=JBEG - JE=JEND - JC=JCPU - IF(IP.EQ.0) IP=1 - IF(IS.EQ.0) IS=1 - IF(JN.EQ.0) JN=IMAX - IF(JS.EQ.0) JS=-JN - IF(KW.EQ.0) KW=2*MX - IF(KG.EQ.0) KG=IMAX*JMAX - IF(JB.EQ.0) JB=1 - IF(JE.EQ.0) JE=(JMAX+1)/2 - IF(JC.EQ.0) JC=NCPUS() -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(IDIR.LT.0.AND.JBEG.EQ.0) THEN - DO K=1,KMAX - KWS=(K-1)*KW - WAVED(KWS+1:KWS+2*MX)=0 - WAVEZ(KWS+1:KWS+2*MX)=0 - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - CALL SPTRANFV(IROMB,MAXWV,IDRT,IMAX,JMAX,KMAX, - & IP,IS,JN,JS,KW,KG,JB,JE,JC, - & WAVED,WAVEZ,GRIDUN,GRIDUS,GRIDVN,GRIDVS,IDIR) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrun.f b/external/sp/v2.0.2/src/sptrun.f deleted file mode 100644 index a3b473061..000000000 --- a/external/sp/v2.0.2/src/sptrun.f +++ /dev/null @@ -1,113 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,IDRTO,IMAXO,JMAXO, - & KMAX,IPRIME,ISKIPI,JSKIPI,KSKIPI, - & ISKIPO,JSKIPO,KSKIPO,JCPU,GRIDI,GRIDO) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUN SPECTRALLY TRUNCATE GRIDDED SCALAR FIELDS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO A POSSIBLY DIFFERENT GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C EITHER GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,IDRTO,IMAXO,JMAXO, -C & KMAX,IPRIME,ISKIPI,JSKIPI,KSKIPI, -C & ISKIPO,JSKIPO,KSKIPO,JCPU,GRIDI,GRIDO) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C IDRTO - INTEGER OUTPUT GRID IDENTIFIER -C (IDRTO=4 FOR GAUSSIAN GRID, -C IDRTO=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTO=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXO - INTEGER EVEN NUMBER OF OUTPUT LONGITUDES. -C JMAXO - INTEGER NUMBER OF OUTPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C ISKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPO=0) -C JSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXO IF JSKIPO=0) -C KSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT GRID FIELDS -C (DEFAULTS TO IMAXO*JMAXO IF KSKIPO=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GRIDO - REAL (*) OUTPUT GRID FIELDS -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL GRIDI(*),GRIDO(*) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRAN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & W,GRIDI(INP),GRIDI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT - JN=-JSKIPO - IF(JN.EQ.0) JN=IMAXO - JS=-JN - INP=(JMAXO-1)*MAX(0,-JN)+1 - ISP=(JMAXO-1)*MAX(0,-JS)+1 - CALL SPTRAN(IROMB,MAXWV,IDRTO,IMAXO,JMAXO,KMAX, - & 0,ISKIPO,JN,JS,MDIM,KSKIPO,0,0,JC, - & W,GRIDO(INP),GRIDO(ISP),1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrund.f b/external/sp/v2.0.2/src/sptrund.f deleted file mode 100644 index 68e1981b9..000000000 --- a/external/sp/v2.0.2/src/sptrund.f +++ /dev/null @@ -1,121 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUND(IROMB,MAXWV,IDRTI,IMAXI,JMAXI, - & IDRTO,IMAXO,JMAXO,KMAX, - & IPRIME,ISKIPI,JSKIPI,KSKIPI, - & ISKIPO,JSKIPO,KSKIPO,JCPU,GRID, - & GRIDMN,GRIDX,GRIDY) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUND SPECTRALLY TRUNCATE TO GRADIENTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THEIR MEANS AND -C GRADIENTS TO A POSSIBLY DIFFERENT GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C EITHER GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUND(IROMB,MAXWV,IDRTI,IMAXI,JMAXI, -C & IDRTO,IMAXO,JMAXO,KMAX, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI, -C & ISKIPO,JSKIPO,KSKIPO,JCPU,GRID, -C & GRIDMN,GRIDX,GRIDY) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C IDRTO - INTEGER OUTPUT GRID IDENTIFIER -C (IDRTO=4 FOR GAUSSIAN GRID, -C IDRTO=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTO=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXO - INTEGER EVEN NUMBER OF OUTPUT LONGITUDES. -C JMAXO - INTEGER NUMBER OF OUTPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C ISKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPO=0) -C JSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXO IF JSKIPO=0) -C KSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT GRID FIELDS -C (DEFAULTS TO IMAXO*JMAXO IF KSKIPO=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRID - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GRIDMN - REAL (KMAX) OUTPUT GLOBAL MEANS -C GRIDX - REAL (*) OUTPUT X-GRADIENTS -C GRIDY - REAL (*) OUTPUT Y-GRADIENTS -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTRAND PERFORM A GRADIENT SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL GRID(*),GRIDX(*),GRIDY(*) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRAN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & W,GRID(INP),GRID(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT GRADIENTS - JN=-JSKIPO - IF(JN.EQ.0) JN=IMAXO - JS=-JN - INP=(JMAXO-1)*MAX(0,-JN)+1 - ISP=(JMAXO-1)*MAX(0,-JS)+1 - CALL SPTRAND(IROMB,MAXWV,IDRTO,IMAXO,JMAXO,KMAX, - & 0,ISKIPO,JN,JS,MDIM,KSKIPO,0,0,JC, - & W,GRIDMN, - & GRIDX(INP),GRIDX(ISP),GRIDY(INP),GRIDY(ISP),1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrung.f b/external/sp/v2.0.2/src/sptrung.f deleted file mode 100644 index b31d9e8bc..000000000 --- a/external/sp/v2.0.2/src/sptrung.f +++ /dev/null @@ -1,104 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUNG(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NMAX, - & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, - & NRSKIP,NGSKIP,JCPU,RLAT,RLON,GRIDI,GP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNG SPECTRALLY INTERPOLATE SCALARS TO STATIONS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO SPECIFIED SETS OF STATION POINTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID AND POINT FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNG(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NMAX, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NRSKIP,NGSKIP,JCPU,RLAT,RLON,GRIDI,GP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GP - REAL (*) STATION POINT SETS -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTGPT TRANSFORM SPECTRAL SCALAR TO STATION POINTS -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL RLAT(*),RLON(*),GRIDI(*),GP(*) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRAN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & W,GRIDI(INP),GRIDI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT - CALL SPTGPT(IROMB,MAXWV,KMAX,NMAX,MDIM,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,W,GP) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrungv.f b/external/sp/v2.0.2/src/sptrungv.f deleted file mode 100644 index ba8f01be6..000000000 --- a/external/sp/v2.0.2/src/sptrungv.f +++ /dev/null @@ -1,153 +0,0 @@ -C------------------------------------------------------------------------- - SUBROUTINE SPTRUNGV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NMAX, - & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, - & NRSKIP,NGSKIP,JCPU,RLAT,RLON,GRIDUI,GRIDVI, - & LUV,UP,VP,LDZ,DP,ZP,LPS,PP,SP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNGV SPECTRALLY INTERPOLATE VECTORS TO STATIONS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES VECTORS FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO SPECIFIED SETS OF STATION POINTS ON THE GLOBE. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID AND POINT FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTRUNGV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NMAX, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NRSKIP,NGSKIP,JCPU,RLAT,RLON,GRIDUI,GRIDVI, -C & LUV,UP,VP,LDZ,DP,ZP,LPS,PP,SP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NMAX - INTEGER NUMBER OF STATION POINTS TO RETURN -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINT SETS -C (DEFAULTS TO NMAX IF KGSKIP=0) -C NRSKIP - INTEGER SKIP NUMBER BETWEEN STATION LATS AND LONS -C (DEFAULTS TO 1 IF NRSKIP=0) -C NGSKIP - INTEGER SKIP NUMBER BETWEEN STATION POINTS -C (DEFAULTS TO 1 IF NGSKIP=0) -C RLAT - REAL (*) STATION LATITUDES IN DEGREES -C RLON - REAL (*) STATION LONGITUDES IN DEGREES -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRIDUI - REAL (*) INPUT GRID U-WINDS -C GRIDVI - REAL (*) INPUT GRID V-WINDS -C LUV - LOGICAL FLAG WHETHER TO RETURN WINDS -C LDZ - LOGICAL FLAG WHETHER TO RETURN DIVERGENCE AND VORTICITY -C LPS - LOGICAL FLAG WHETHER TO RETURN POTENTIAL AND STREAMFCN -C OUTPUT ARGUMENTS: -C UP - REAL (*) STATION U-WINDS IF LUV -C VP - REAL (*) STATION V-WINDS IF LUV -C DP - REAL (*) STATION DIVERGENCES IF LDZ -C ZP - REAL (*) STATION VORTICITIES IF LDZ -C PP - REAL (*) STATION POTENTIALS IF LPS -C SP - REAL (*) STATION STREAMFCNS IF LPS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C SPTGPT TRANSFORM SPECTRAL SCALAR TO STATION POINTS -C SPTGPTV TRANSFORM SPECTRAL VECTOR TO STATION POINTS -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - LOGICAL LUV,LDZ,LPS - REAL RLAT(*),RLON(*),GRIDUI(*),GRIDVI(*) - REAL UP(*),VP(*),DP(*),ZP(*),PP(*),SP(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL WD((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL WZ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRANV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & WD,WZ, - & GRIDUI(INP),GRIDUI(ISP),GRIDVI(INP),GRIDVI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT WINDS - IF(LUV) THEN - CALL SPTGPTV(IROMB,MAXWV,KMAX,NMAX,MDIM,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WD,WZ,UP,VP) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT DIVERGENCE AND VORTICITY - IF(LDZ) THEN - CALL SPTGPT(IROMB,MAXWV,KMAX,NMAX,MDIM,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WD,DP) - CALL SPTGPT(IROMB,MAXWV,KMAX,NMAX,MDIM,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WZ,ZP) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT POTENTIAL AND STREAMFUNCTION - IF(LPS) THEN - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C$OMP PARALLEL DO - DO K=1,KMAX - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WD(1,K),WD(1,K),-1) - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WZ(1,K),WZ(1,K),-1) - WD(1:2,K)=0. - WZ(1:2,K)=0. - ENDDO - CALL SPTGPT(IROMB,MAXWV,KMAX,NMAX,MDIM,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WD,PP) - CALL SPTGPT(IROMB,MAXWV,KMAX,NMAX,MDIM,KGSKIP,NRSKIP,NGSKIP, - & RLAT,RLON,WZ,SP) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrunl.f b/external/sp/v2.0.2/src/sptrunl.f deleted file mode 100644 index e150de186..000000000 --- a/external/sp/v2.0.2/src/sptrunl.f +++ /dev/null @@ -1,127 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUNL(IROMB,MAXWV,IDRTI,IMAXI,JMAXI, - & IDRTO,IMAXO,JMAXO,KMAX, - & IPRIME,ISKIPI,JSKIPI,KSKIPI, - & ISKIPO,JSKIPO,KSKIPO,JCPU,IDIR,GRIDI,GRIDO) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNL SPECTRALLY TRUNCATE TO LAPLACIAN -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THEIR LAPLACIAN -C OR INVERSE TO A POSSIBLY DIFFERENT GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C EITHER GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTRUNL(IROMB,MAXWV,IDRTI,IMAXI,JMAXI, -C & IDRTO,IMAXO,JMAXO,KMAX, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI, -C & ISKIPO,JSKIPO,KSKIPO,JCPU,IDIR,GRIDI,GRIDO) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C IDRTO - INTEGER OUTPUT GRID IDENTIFIER -C (IDRTO=4 FOR GAUSSIAN GRID, -C IDRTO=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTO=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXO - INTEGER EVEN NUMBER OF OUTPUT LONGITUDES. -C JMAXO - INTEGER NUMBER OF OUTPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C ISKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPO=0) -C JSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXO IF JSKIPO=0) -C KSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT GRID FIELDS -C (DEFAULTS TO IMAXO*JMAXO IF KSKIPO=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C IDIR - INTEGER FLAG -C IDIR > 0 TO TAKE LAPLACIAN -C IDIR < 0 TO TAKE INVERSE LAPLACIAN -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GRIDO - REAL (*) OUTPUT GRID FIELDS -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL GRIDI(*),GRIDO(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRAN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & W,GRIDI(INP),GRIDI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TAKE LAPLACIAN AND TRANSFORM WAVE TO OUTPUT GRID - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C$OMP PARALLEL DO - DO K=1,KMAX - CALL SPLAPLAC(IROMB,MAXWV,ENN1,W(1,K),W(1,K),IDIR) - W(1:2,K)=0. - ENDDO - CALL SPTRAN(IROMB,MAXWV,IDRTO,IMAXO,JMAXO,KMAX, - & 0,ISKIPO,JN,JS,MDIM,KSKIPO,0,0,JC, - & W,GRIDO(INP),GRIDO(ISP),1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrunm.f b/external/sp/v2.0.2/src/sptrunm.f deleted file mode 100644 index c9497974c..000000000 --- a/external/sp/v2.0.2/src/sptrunm.f +++ /dev/null @@ -1,117 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUNM(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,MI,MJ, - & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, - & NISKIP,NJSKIP,JCPU,RLAT1,RLON1,DLAT,DLON, - & GRIDI,GM) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNM SPECTRALLY INTERPOLATE SCALARS TO MERCATOR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNM(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,MI,MJ, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NISKIP,NJSKIP,JCPU,RLAT1,RLON1,DLAT,DLON, -C & GRIDI,GM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GM - REAL (*) MERCATOR FIELDS -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTGPM TRANSFORM SPECTRAL SCALAR TO MERCATOR -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL GRIDI(*),GM(*) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRAN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & W,GRIDI(INP),GRIDI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT - CALL SPTGPM(IROMB,MAXWV,KMAX,MI,MJ,MDIM,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,W,GM) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrunmv.f b/external/sp/v2.0.2/src/sptrunmv.f deleted file mode 100644 index e32a73890..000000000 --- a/external/sp/v2.0.2/src/sptrunmv.f +++ /dev/null @@ -1,165 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUNMV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,MI,MJ, - & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, - & NISKIP,NJSKIP,JCPU,RLAT1,RLON1,DLAT,DLON, - & GRIDUI,GRIDVI,LUV,UM,VM,LDZ,DM,ZM,LPS,PM,SM) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNMV SPECTRALLY INTERPOLATE VECTORS TO MERCATOR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES VECTOR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO A MERCATOR GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTRUNMV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,MI,MJ, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NISKIP,NJSKIP,JCPU,RLAT1,RLON1,DLAT,DLON, -C & GRIDUI,GRIDVI,LUV,UM,VM,LDZ,DM,ZM,LPS,PM,SM) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C MI - INTEGER NUMBER OF POINTS IN THE FASTER ZONAL DIRECTION -C MJ - INTEGER NUMBER OF POINTS IN THE SLOWER MERID DIRECTION -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO MI*MJ IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO MI IF NJSKIP=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C RLAT1 - REAL LATITUDE OF THE FIRST GRID POINT IN DEGREES -C RLON1 - REAL LONGITUDE OF THE FIRST GRID POINT IN DEGREES -C DLAT - REAL LATITUDE INCREMENT IN DEGREES SUCH THAT -C D(PHI)/D(J)=DLAT*COS(PHI) WHERE J IS MERIDIONAL INDEX. -C DLAT IS NEGATIVE FOR GRIDS INDEXED SOUTHWARD. -C (IN TERMS OF GRID INCREMENT DY VALID AT LATITUDE RLATI, -C THE LATITUDE INCREMENT DLAT IS DETERMINED AS -C DLAT=DPR*DY/(RERTH*COS(RLATI/DPR)) -C WHERE DPR=180/PI AND RERTH IS EARTH'S RADIUS) -C DLON - REAL LONGITUDE INCREMENT IN DEGREES SUCH THAT -C D(LAMBDA)/D(I)=DLON WHERE I IS ZONAL INDEX. -C DLON IS NEGATIVE FOR GRIDS INDEXED WESTWARD. -C GRIDUI - REAL (*) INPUT GRID U-WINDS -C GRIDVI - REAL (*) INPUT GRID V-WINDS -C LUV - LOGICAL FLAG WHETHER TO RETURN WINDS -C LDZ - LOGICAL FLAG WHETHER TO RETURN DIVERGENCE AND VORTICITY -C LPS - LOGICAL FLAG WHETHER TO RETURN POTENTIAL AND STREAMFCN -C OUTPUT ARGUMENTS: -C UM - REAL (*) MERCATOR U-WINDS IF LUV -C VM - REAL (*) MERCATOR V-WINDS IF LUV -C DM - REAL (*) MERCATOR DIVERGENCES IF LDZ -C ZM - REAL (*) MERCATOR VORTICITIES IF LDZ -C PM - REAL (*) MERCATOR POTENTIALS IF LPS -C SM - REAL (*) MERCATOR STREAMFCNS IF LPS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C SPTGPM TRANSFORM SPECTRAL SCALAR TO MERCATOR -C SPTGPMV TRANSFORM SPECTRAL VECTOR TO MERCATOR -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - LOGICAL LUV,LDZ,LPS - REAL GRIDUI(*),GRIDVI(*) - REAL UM(*),VM(*),DM(*),ZM(*),PM(*),SM(*) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL WD((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL WZ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRANV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & WD,WZ, - & GRIDUI(INP),GRIDUI(ISP),GRIDVI(INP),GRIDVI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT WINDS - IF(LUV) THEN - CALL SPTGPMV(IROMB,MAXWV,KMAX,MI,MJ,MDIM,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WD,WZ,UM,VM) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT DIVERGENCE AND VORTICITY - IF(LDZ) THEN - CALL SPTGPM(IROMB,MAXWV,KMAX,MI,MJ,MDIM,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WD,DM) - CALL SPTGPM(IROMB,MAXWV,KMAX,MI,MJ,MDIM,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WZ,ZM) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT POTENTIAL AND STREAMFUNCTION - IF(LPS) THEN - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C$OMP PARALLEL DO - DO K=1,KMAX - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WD(1,K),WD(1,K),-1) - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WZ(1,K),WZ(1,K),-1) - WD(1:2,K)=0. - WZ(1:2,K)=0. - ENDDO - CALL SPTGPM(IROMB,MAXWV,KMAX,MI,MJ,MDIM,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WD,PM) - CALL SPTGPM(IROMB,MAXWV,KMAX,MI,MJ,MDIM,KGSKIP,NISKIP,NJSKIP, - & RLAT1,RLON1,DLAT,DLON,WZ,SM) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptruns.f b/external/sp/v2.0.2/src/sptruns.f deleted file mode 100644 index a12bdc8c5..000000000 --- a/external/sp/v2.0.2/src/sptruns.f +++ /dev/null @@ -1,109 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUNS(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NPS, - & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, - & NISKIP,NJSKIP,JCPU,TRUE,XMESH,ORIENT, - & GRIDI,GN,GS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNS SPECTRALLY INTERPOLATE SCALARS TO POLAR STEREO -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO SPECIFIC PAIRS OF POLAR STEREOGRAPHIC SCALAR FIELDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPTRUNS(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NPS, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NISKIP,NJSKIP,JCPU,TRUE,XMESH,ORIENT, -C & GRIDI,GN,GS) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C GRIDI - REAL (*) INPUT GRID FIELDS -C OUTPUT ARGUMENTS: -C GN - REAL (*) NORTHERN POLAR STEREOGRAPHIC FIELDS -C GS - REAL (*) SOUTHERN POLAR STEREOGRAPHIC FIELDS -C -C SUBPROGRAMS CALLED: -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTGPS TRANSFORM SPECTRAL SCALAR TO POLAR STEREO. -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL GRIDI(*),GN(*),GS(*) - REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRAN(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & W,GRIDI(INP),GRIDI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT - CALL SPTGPS(IROMB,MAXWV,KMAX,NPS,MDIM,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,W,GN,GS) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrunsv.f b/external/sp/v2.0.2/src/sptrunsv.f deleted file mode 100644 index cfdfe4a5f..000000000 --- a/external/sp/v2.0.2/src/sptrunsv.f +++ /dev/null @@ -1,166 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUNSV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NPS, - & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, - & NISKIP,NJSKIP,JCPU,TRUE,XMESH,ORIENT, - & GRIDUI,GRIDVI, - & LUV,UN,VN,US,VS,LDZ,DN,ZN,DS,ZS, - & LPS,PN,SN,PS,SS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNSV SPECTRALLY INTERPOLATE VECTORS TO POLAR STEREO -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES VECTOR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO SPECIFIC PAIRS OF POLAR STEREOGRAPHIC SCALAR FIELDS. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C THE GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTRUNSV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX,NPS, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI,KGSKIP, -C & NISKIP,NJSKIP,JCPU,TRUE,XMESH,ORIENT, -C & GRIDUI,GRIDVI, -C & LUV,UN,VN,US,VS,LDZ,DN,ZN,DS,ZS, -C & LPS,PN,SN,PS,SS) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C NPS - INTEGER ODD ORDER OF THE POLAR STEREOGRAPHIC GRIDS -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C KGSKIP - INTEGER SKIP NUMBER BETWEEN GRID FIELDS -C (DEFAULTS TO NPS*NPS IF KGSKIP=0) -C NISKIP - INTEGER SKIP NUMBER BETWEEN GRID I-POINTS -C (DEFAULTS TO 1 IF NISKIP=0) -C NJSKIP - INTEGER SKIP NUMBER BETWEEN GRID J-POINTS -C (DEFAULTS TO NPS IF NJSKIP=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C TRUE - REAL LATITUDE AT WHICH PS GRID IS TRUE (USUALLY 60.) -C XMESH - REAL GRID LENGTH AT TRUE LATITUDE (M) -C ORIENT - REAL LONGITUDE AT BOTTOM OF NORTHERN PS GRID -C (SOUTHERN PS GRID WILL HAVE OPPOSITE ORIENTATION.) -C GRIDUI - REAL (*) INPUT GRID U-WINDS -C GRIDVI - REAL (*) INPUT GRID V-WINDS -C LUV - LOGICAL FLAG WHETHER TO RETURN WINDS -C LDZ - LOGICAL FLAG WHETHER TO RETURN DIVERGENCE AND VORTICITY -C LPS - LOGICAL FLAG WHETHER TO RETURN POTENTIAL AND STREAMFCN -C OUTPUT ARGUMENTS: -C UN - REAL (*) NORTHERN PS U-WINDS IF LUV -C VN - REAL (*) NORTHERN PS V-WINDS IF LUV -C US - REAL (*) SOUTHERN PS U-WINDS IF LUV -C VS - REAL (*) SOUTHERN PS V-WINDS IF LUV -C DN - REAL (*) NORTHERN DIVERGENCES IF LDZ -C ZN - REAL (*) NORTHERN VORTICITIES IF LDZ -C DS - REAL (*) SOUTHERN DIVERGENCES IF LDZ -C ZS - REAL (*) SOUTHERN VORTICITIES IF LDZ -C PN - REAL (*) NORTHERN POTENTIALS IF LPS -C SN - REAL (*) NORTHERN STREAMFCNS IF LPS -C PS - REAL (*) SOUTHERN POTENTIALS IF LPS -C SS - REAL (*) SOUTHERN STREAMFCNS IF LPS -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C SPTGPS TRANSFORM SPECTRAL SCALAR TO POLAR STEREO. -C SPTGPSV TRANSFORM SPECTRAL VECTOR TO POLAR STEREO. -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - LOGICAL LUV,LDZ,LPS - REAL GRIDUI(*),GRIDVI(*) - REAL UN(*),VN(*),US(*),VS(*),DN(*),ZN(*),DS(*),ZS(*) - REAL PN(*),SN(*),PS(*),SS(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL WD((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL WZ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRANV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & WD,WZ, - & GRIDUI(INP),GRIDUI(ISP),GRIDVI(INP),GRIDVI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT WINDS - IF(LUV) THEN - CALL SPTGPSV(IROMB,MAXWV,KMAX,NPS,MDIM,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WD,WZ,UN,VN,US,VS) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT DIVERGENCE AND VORTICITY - IF(LDZ) THEN - CALL SPTGPS(IROMB,MAXWV,KMAX,NPS,MDIM,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WD,DN,DS) - CALL SPTGPS(IROMB,MAXWV,KMAX,NPS,MDIM,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WZ,ZN,ZS) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT POTENTIAL AND STREAMFUNCTION - IF(LPS) THEN - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C$OMP PARALLEL DO - DO K=1,KMAX - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WD(1,K),WD(1,K),-1) - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WZ(1,K),WZ(1,K),-1) - WD(1:2,K)=0. - WZ(1:2,K)=0. - ENDDO - CALL SPTGPS(IROMB,MAXWV,KMAX,NPS,MDIM,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WD,PN,PS) - CALL SPTGPS(IROMB,MAXWV,KMAX,NPS,MDIM,KGSKIP,NISKIP,NJSKIP, - & TRUE,XMESH,ORIENT,WZ,SN,SS) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/sptrunv.f b/external/sp/v2.0.2/src/sptrunv.f deleted file mode 100644 index 95638687e..000000000 --- a/external/sp/v2.0.2/src/sptrunv.f +++ /dev/null @@ -1,177 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPTRUNV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI, - & IDRTO,IMAXO,JMAXO,KMAX, - & IPRIME,ISKIPI,JSKIPI,KSKIPI, - & ISKIPO,JSKIPO,KSKIPO,JCPU,GRIDUI,GRIDVI, - & LUV,GRIDUO,GRIDVO,LDZ,GRIDDO,GRIDZO, - & LPS,GRIDPO,GRIDSO) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPTRUNV SPECTRALLY TRUNCATE GRIDDED VECTOR FIELDS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM SPECTRALLY TRUNCATES VECTOR FIELDS -C ON A GLOBAL CYLINDRICAL GRID, RETURNING THE FIELDS -C TO A POSSIBLY DIFFERENT GLOBAL CYLINDRICAL GRID. -C THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL. -C EITHER GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID -C (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID. -C THE GRID FIELDS MAY HAVE GENERAL INDEXING. -C THE TRANSFORMS ARE ALL MULTIPROCESSED. -C OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY. -C TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C 1998-12-15 IREDELL OPENMP DIRECTIVES INSERTED -C -C USAGE: CALL SPTRUNV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI, -C & IDRTO,IMAXO,JMAXO,KMAX, -C & IPRIME,ISKIPI,JSKIPI,KSKIPI, -C & ISKIPO,JSKIPO,KSKIPO,JCPU,GRIDUI,GRIDVI, -C & LUV,GRIDUO,GRIDVO,LDZ,GRIDDO,GRIDZO, -C & LPS,GRIDPO,GRIDSO) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C IDRTI - INTEGER INPUT GRID IDENTIFIER -C (IDRTI=4 FOR GAUSSIAN GRID, -C IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES. -C JMAXI - INTEGER NUMBER OF INPUT LATITUDES. -C IDRTO - INTEGER OUTPUT GRID IDENTIFIER -C (IDRTO=4 FOR GAUSSIAN GRID, -C IDRTO=0 FOR EQUALLY-SPACED GRID INCLUDING POLES, -C IDRTO=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES) -C IMAXO - INTEGER EVEN NUMBER OF OUTPUT LONGITUDES. -C JMAXO - INTEGER NUMBER OF OUTPUT LATITUDES. -C KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM. -C IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN. -C (DEFAULTS TO 1 IF IPRIME=0) -C (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.) -C ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPI=0) -C JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXI IF JSKIPI=0) -C KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS -C (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0) -C ISKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LONGITUDES -C (DEFAULTS TO 1 IF ISKIPO=0) -C JSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LATITUDES FROM SOUTH -C (DEFAULTS TO -IMAXO IF JSKIPO=0) -C KSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT GRID FIELDS -C (DEFAULTS TO IMAXO*JMAXO IF KSKIPO=0) -C JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS -C (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0) -C GRIDUI - REAL (*) INPUT GRID U-WINDS -C GRIDVI - REAL (*) INPUT GRID V-WINDS -C LUV - LOGICAL FLAG WHETHER TO RETURN WINDS -C LDZ - LOGICAL FLAG WHETHER TO RETURN DIVERGENCE AND VORTICITY -C LPS - LOGICAL FLAG WHETHER TO RETURN POTENTIAL AND STREAMFCN -C OUTPUT ARGUMENTS: -C GRIDUO - REAL (*) OUTPUT U-WINDS IF LUV -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDVO - REAL (*) OUTPUT V-WINDS IF LUV -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDDO - REAL (*) OUTPUT DIVERGENCES IF LDZ -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDZO - REAL (*) OUTPUT VORTICITIES IF LDZ -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDPO - REAL (*) OUTPUT POTENTIALS IF LPS -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C GRIDSO - REAL (*) OUTPUT STREAMFCNS IF LPS -C (MAY OVERLAY INPUT FIELDS IF GRID SHAPE IS APPROPRIATE) -C -C SUBPROGRAMS CALLED: -C SPWGET GET WAVE-SPACE CONSTANTS -C SPLAPLAC COMPUTE LAPLACIAN IN SPECTRAL SPACE -C SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM -C SPTRANV PERFORM A VECTOR SPHERICAL TRANSFORM -C NCPUS GETS ENVIRONMENT NUMBER OF CPUS -C -C REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL: -C DIMENSION LINEAR QUADRATIC -C ----------------------- --------- ------------- -C IMAX 2*MAXWV+2 3*MAXWV/2*2+2 -C JMAX (IDRT=4,IROMB=0) 1*MAXWV+1 3*MAXWV/2+1 -C JMAX (IDRT=4,IROMB=1) 2*MAXWV+1 5*MAXWV/2+1 -C JMAX (IDRT=0,IROMB=0) 2*MAXWV+3 3*MAXWV/2*2+3 -C JMAX (IDRT=0,IROMB=1) 4*MAXWV+3 5*MAXWV/2*2+3 -C JMAX (IDRT=256,IROMB=0) 2*MAXWV+1 3*MAXWV/2*2+1 -C JMAX (IDRT=256,IROMB=1) 4*MAXWV+1 5*MAXWV/2*2+1 -C ----------------------- --------- ------------- -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - LOGICAL LUV,LDZ,LPS - REAL GRIDUI(*),GRIDVI(*) - REAL GRIDUO(*),GRIDVO(*),GRIDDO(*),GRIDZO(*),GRIDPO(*),GRIDSO(*) - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) - REAL WD((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) - REAL WZ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM INPUT GRID TO WAVE - JC=JCPU - IF(JC.EQ.0) JC=NCPUS() - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MDIM=2*MX+1 - JN=-JSKIPI - IF(JN.EQ.0) JN=IMAXI - JS=-JN - INP=(JMAXI-1)*MAX(0,-JN)+1 - ISP=(JMAXI-1)*MAX(0,-JS)+1 - CALL SPTRANV(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,KMAX, - & IPRIME,ISKIPI,JN,JS,MDIM,KSKIPI,0,0,JC, - & WD,WZ, - & GRIDUI(INP),GRIDUI(ISP),GRIDVI(INP),GRIDVI(ISP),-1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT WINDS - JN=-JSKIPO - IF(JN.EQ.0) JN=IMAXO - JS=-JN - INP=(JMAXO-1)*MAX(0,-JN)+1 - ISP=(JMAXO-1)*MAX(0,-JS)+1 - IF(LUV) THEN - CALL SPTRANV(IROMB,MAXWV,IDRTO,IMAXO,JMAXO,KMAX, - & 0,ISKIPO,JN,JS,MDIM,KSKIPO,0,0,JC, - & WD,WZ, - & GRIDUO(INP),GRIDUO(ISP),GRIDVO(INP),GRIDVO(ISP),1) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT DIVERGENCE AND VORTICITY - IF(LDZ) THEN - CALL SPTRAN(IROMB,MAXWV,IDRTO,IMAXO,JMAXO,KMAX, - & 0,ISKIPO,JN,JS,MDIM,KSKIPO,0,0,JC, - & WD,GRIDDO(INP),GRIDDO(ISP),1) - CALL SPTRAN(IROMB,MAXWV,IDRTO,IMAXO,JMAXO,KMAX, - & 0,ISKIPO,JN,JS,MDIM,KSKIPO,0,0,JC, - & WZ,GRIDZO(INP),GRIDZO(ISP),1) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C TRANSFORM WAVE TO OUTPUT POTENTIAL AND STREAMFUNCTION - IF(LPS) THEN - CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C$OMP PARALLEL DO - DO K=1,KMAX - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WD(1,K),WD(1,K),-1) - CALL SPLAPLAC(IROMB,MAXWV,ENN1,WZ(1,K),WZ(1,K),-1) - WD(1:2,K)=0. - WZ(1:2,K)=0. - ENDDO - CALL SPTRAN(IROMB,MAXWV,IDRTO,IMAXO,JMAXO,KMAX, - & 0,ISKIPO,JN,JS,MDIM,KSKIPO,0,0,JC, - & WD,GRIDPO(INP),GRIDPO(ISP),1) - CALL SPTRAN(IROMB,MAXWV,IDRTO,IMAXO,JMAXO,KMAX, - & 0,ISKIPO,JN,JS,MDIM,KSKIPO,0,0,JC, - & WZ,GRIDSO(INP),GRIDSO(ISP),1) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/sp/v2.0.2/src/spuv2dz.f b/external/sp/v2.0.2/src/spuv2dz.f deleted file mode 100644 index 573a23778..000000000 --- a/external/sp/v2.0.2/src/spuv2dz.f +++ /dev/null @@ -1,94 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPUV2DZ(I,M,ENN1,ELONN1,EON,EONTOP,U,V,UTOP,VTOP,D,Z) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPUV2DZ COMPUTE DIVERGENCE AND VORTICITY FROM WINDS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE DIVERGENCE AND VORTICITY FROM WIND COMPONENTS -C IN SPECTRAL SPACE. -C SUBPROGRAM SPEPS SHOULD BE CALLED ALREADY. -C IF L IS THE ZONAL WAVENUMBER, N IS THE TOTAL WAVENUMBER, -C EPS(L,N)=SQRT((N**2-L**2)/(4*N**2-1)) AND A IS EARTH RADIUS, -C THEN THE DIVERGENCE D IS COMPUTED AS -C D(L,N)=I*L*A*U(L,N) -C +EPS(L,N+1)*N*A*V(L,N+1)-EPS(L,N)*(N+1)*A*V(L,N-1) -C AND THE VORTICITY Z IS COMPUTED AS -C Z(L,N)=I*L*A*V(L,N) -C -EPS(L,N+1)*N*A*U(L,N+1)+EPS(L,N)*(N+1)*A*U(L,N-1) -C WHERE U IS THE ZONAL WIND AND V IS THE MERIDIONAL WIND. -C U AND V ARE WEIGHTED BY THE SECANT OF LATITUDE. -C EXTRA TERMS ARE USED OVER TOP OF THE SPECTRAL DOMAIN. -C ADVANTAGE IS TAKEN OF THE FACT THAT EPS(L,L)=0 -C IN ORDER TO VECTORIZE OVER THE ENTIRE SPECTRAL DOMAIN. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPUV2DZ(I,M,ENN1,ELONN1,EON,EONTOP,U,V,UTOP,VTOP,D,Z) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C ENN1 - REAL ((M+1)*((I+1)*M+2)/2) N*(N+1)/A**2 -C ELONN1 - REAL ((M+1)*((I+1)*M+2)/2) L/(N*(N+1))*A -C EON - REAL ((M+1)*((I+1)*M+2)/2) EPSILON/N*A -C EONTOP - REAL (M+1) EPSILON/N*A OVER TOP -C U - REAL ((M+1)*((I+1)*M+2)) ZONAL WIND (OVER COSLAT) -C V - REAL ((M+1)*((I+1)*M+2)) MERID WIND (OVER COSLAT) -C UTOP - REAL (2*(M+1)) ZONAL WIND (OVER COSLAT) OVER TOP -C VTOP - REAL (2*(M+1)) MERID WIND (OVER COSLAT) OVER TOP -C -C OUTPUT ARGUMENT LIST: -C D - REAL ((M+1)*((I+1)*M+2)) DIVERGENCE -C Z - REAL ((M+1)*((I+1)*M+2)) VORTICITY -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - REAL ENN1((M+1)*((I+1)*M+2)/2),ELONN1((M+1)*((I+1)*M+2)/2) - REAL EON((M+1)*((I+1)*M+2)/2),EONTOP(M+1) - REAL U((M+1)*((I+1)*M+2)),V((M+1)*((I+1)*M+2)) - REAL UTOP(2*(M+1)),VTOP(2*(M+1)) - REAL D((M+1)*((I+1)*M+2)),Z((M+1)*((I+1)*M+2)) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE TERMS FROM THE SPECTRAL DOMAIN - K=1 - D(2*K-1)=0. - D(2*K)=0. - Z(2*K-1)=0. - Z(2*K)=0. - DO K=2,(M+1)*((I+1)*M+2)/2-1 - D(2*K-1)=-ELONN1(K)*U(2*K)+EON(K+1)*V(2*K+1)-EON(K)*V(2*K-3) - D(2*K)=ELONN1(K)*U(2*K-1)+EON(K+1)*V(2*K+2)-EON(K)*V(2*K-2) - Z(2*K-1)=-ELONN1(K)*V(2*K)-EON(K+1)*U(2*K+1)+EON(K)*U(2*K-3) - Z(2*K)=ELONN1(K)*V(2*K-1)-EON(K+1)*U(2*K+2)+EON(K)*U(2*K-2) - ENDDO - K=(M+1)*((I+1)*M+2)/2 - D(2*K-1)=-ELONN1(K)*U(2*K)-EON(K)*V(2*K-3) - D(2*K)=ELONN1(K)*U(2*K-1)-EON(K)*V(2*K-2) - Z(2*K-1)=-ELONN1(K)*V(2*K)+EON(K)*U(2*K-3) - Z(2*K)=ELONN1(K)*V(2*K-1)+EON(K)*U(2*K-2) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE TERMS FROM OVER TOP OF THE SPECTRAL DOMAIN -CDIR$ IVDEP - DO L=0,M - K=L*(2*M+(I-1)*(L-1))/2+I*L+M+1 - D(2*K-1)=D(2*K-1)+EONTOP(L+1)*VTOP(2*L+1) - D(2*K)=D(2*K)+EONTOP(L+1)*VTOP(2*L+2) - Z(2*K-1)=Z(2*K-1)-EONTOP(L+1)*UTOP(2*L+1) - Z(2*K)=Z(2*K)-EONTOP(L+1)*UTOP(2*L+2) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C MULTIPLY BY LAPLACIAN TERM - DO K=2,(M+1)*((I+1)*M+2)/2 - D(2*K-1)=D(2*K-1)*ENN1(K) - D(2*K)=D(2*K)*ENN1(K) - Z(2*K-1)=Z(2*K-1)*ENN1(K) - Z(2*K)=Z(2*K)*ENN1(K) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/spvar.f b/external/sp/v2.0.2/src/spvar.f deleted file mode 100644 index 87187e974..000000000 --- a/external/sp/v2.0.2/src/spvar.f +++ /dev/null @@ -1,48 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPVAR(I,M,Q,QVAR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPVAR COMPUTE VARIANCE BY TOTAL WAVENUMBER -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: COMPUTES THE VARIANCES BY TOTAL WAVENUMBER -C OF A SCALAR FIELD IN SPECTRAL SPACE. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C -C USAGE: CALL SPVAR(I,M,Q,QVAR) -C -C INPUT ARGUMENT LIST: -C I - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C M - INTEGER SPECTRAL TRUNCATION -C Q - REAL ((M+1)*((I+1)*M+2)) SCALAR FIELD -C -C OUTPUT ARGUMENT LIST: -C QVAR - REAL (0:(I+1)*M) VARIANCES -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - REAL Q((M+1)*((I+1)*M+2)) - REAL QVAR(0:(I+1)*M) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - L=0 - DO N=0,M - KS=L*(2*M+(I-1)*(L-1))+2*N - QVAR(N)=0.5*Q(KS+1)**2 - ENDDO - DO N=M+1,(I+1)*M - QVAR(N)=0. - ENDDO - DO N=0,(I+1)*M - DO L=MAX(1,N-M),MIN(N,M) - KS=L*(2*M+(I-1)*(L-1))+2*N - QVAR(N)=QVAR(N)+Q(KS+1)**2+Q(KS+2)**2 - ENDDO - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/sp/v2.0.2/src/spwget.f b/external/sp/v2.0.2/src/spwget.f deleted file mode 100644 index 171a8b4fc..000000000 --- a/external/sp/v2.0.2/src/spwget.f +++ /dev/null @@ -1,41 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SPWGET GET WAVE-SPACE CONSTANTS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-02-29 -C -C ABSTRACT: THIS SUBPROGRAM GETS WAVE-SPACE CONSTANTS. -C -C PROGRAM HISTORY LOG: -C 96-02-29 IREDELL -C -C USAGE: CALL SPWGET(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) -C INPUT ARGUMENTS: -C IROMB - INTEGER SPECTRAL DOMAIN SHAPE -C (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL) -C MAXWV - INTEGER SPECTRAL TRUNCATION -C OUTPUT ARGUMENTS: -C EPS - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EPSTOP - REAL (MAXWV+1) -C ENN1 - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C ELONN1 - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EON - REAL ((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) -C EONTOP - REAL (MAXWV+1) -C -C SUBPROGRAMS CALLED: -C SPEPS COMPUTE UTILITY SPECTRAL FIELDS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C -C$$$ - REAL EPS((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EPSTOP(MAXWV+1) - REAL ENN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL ELONN1((MAXWV+1)*((IROMB+1)*MAXWV+2)/2) - REAL EON((MAXWV+1)*((IROMB+1)*MAXWV+2)/2),EONTOP(MAXWV+1) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - MX=(MAXWV+1)*((IROMB+1)*MAXWV+2)/2 - MXTOP=MAXWV+1 - CALL SPEPS(IROMB,MAXWV,EPS,EPSTOP,ENN1,ELONN1,EON,EONTOP) - END diff --git a/external/w3nco/v2.0.6/src/CMakeLists.txt b/external/w3nco/v2.0.6/src/CMakeLists.txt deleted file mode 100644 index 186bbc6e9..000000000 --- a/external/w3nco/v2.0.6/src/CMakeLists.txt +++ /dev/null @@ -1,155 +0,0 @@ -SET(W3_source_code ${W3LIB_SRC}/aea.f - ${W3LIB_SRC}/errexit.f - ${W3LIB_SRC}/errmsg.f - ${W3LIB_SRC}/fparsei.f - ${W3LIB_SRC}/fparser.f - ${W3LIB_SRC}/gbyte.f - ${W3LIB_SRC}/gbytec.f - ${W3LIB_SRC}/gbytes.f - ${W3LIB_SRC}/gbytesc.f - ${W3LIB_SRC}/getbit.f - ${W3LIB_SRC}/getgb.f - ${W3LIB_SRC}/getgb1.f - ${W3LIB_SRC}/getgb1r.f - ${W3LIB_SRC}/getgb1re.f - ${W3LIB_SRC}/getgb1s.f - ${W3LIB_SRC}/getgbe.f - ${W3LIB_SRC}/getgbeh.f - ${W3LIB_SRC}/getgbem.f - ${W3LIB_SRC}/getgbemh.f - ${W3LIB_SRC}/getgbemn.f - ${W3LIB_SRC}/getgbemp.f - ${W3LIB_SRC}/getgbep.f - ${W3LIB_SRC}/getgbex.f - ${W3LIB_SRC}/getgbexm.f - ${W3LIB_SRC}/getgbh.f - ${W3LIB_SRC}/getgbm.f - ${W3LIB_SRC}/getgbmh.f - ${W3LIB_SRC}/getgbmp.f - ${W3LIB_SRC}/getgbp.f - ${W3LIB_SRC}/getgi.f - ${W3LIB_SRC}/getgir.f - ${W3LIB_SRC}/gtbits.f - ${W3LIB_SRC}/idsdef.f - ${W3LIB_SRC}/instrument.f - ${W3LIB_SRC}/iw3jdn.f - ${W3LIB_SRC}/iw3pds.f - ${W3LIB_SRC}/iw3unp29.f - ${W3LIB_SRC}/ixgb.f - ${W3LIB_SRC}/lengds.f - ${W3LIB_SRC}/makwmo.f - ${W3LIB_SRC}/mkfldsep.f - ${W3LIB_SRC}/mova2i.c - ${W3LIB_SRC}/pdsens.f - ${W3LIB_SRC}/pdseup.f - ${W3LIB_SRC}/putgb.f - ${W3LIB_SRC}/putgbe.f - ${W3LIB_SRC}/putgben.f - ${W3LIB_SRC}/putgbex.f - ${W3LIB_SRC}/putgbn.f - ${W3LIB_SRC}/q9ie32.f - ${W3LIB_SRC}/r63w72.f - ${W3LIB_SRC}/sbyte.f - ${W3LIB_SRC}/sbytec.f - ${W3LIB_SRC}/sbytes.f - ${W3LIB_SRC}/sbytesc.f - ${W3LIB_SRC}/skgb.f - #${W3LIB_SRC}/summary.c - ${W3LIB_SRC}/w3ai00.f - ${W3LIB_SRC}/w3ai01.f - ${W3LIB_SRC}/w3ai08.f - ${W3LIB_SRC}/w3ai15.f - ${W3LIB_SRC}/w3ai18.f - ${W3LIB_SRC}/w3ai19.f - ${W3LIB_SRC}/w3ai24.f - ${W3LIB_SRC}/w3ai38.f - ${W3LIB_SRC}/w3ai39.f - ${W3LIB_SRC}/w3aq15.f - ${W3LIB_SRC}/w3as00.f - ${W3LIB_SRC}/w3difdat.f - ${W3LIB_SRC}/w3doxdat.f - ${W3LIB_SRC}/w3fi01.f - ${W3LIB_SRC}/w3fi04.f - ${W3LIB_SRC}/w3fi58.f - ${W3LIB_SRC}/w3fi59.f - ${W3LIB_SRC}/w3fi62.f - ${W3LIB_SRC}/w3fi63.f - ${W3LIB_SRC}/w3fi64.f - ${W3LIB_SRC}/w3fi68.f - ${W3LIB_SRC}/w3fi69.f - ${W3LIB_SRC}/w3fi71.f - ${W3LIB_SRC}/w3fi72.f - ${W3LIB_SRC}/w3fi73.f - ${W3LIB_SRC}/w3fi74.f - ${W3LIB_SRC}/w3fi75.f - ${W3LIB_SRC}/w3fi76.f - ${W3LIB_SRC}/w3fi82.f - ${W3LIB_SRC}/w3fi83.f - ${W3LIB_SRC}/w3fi88.f - ${W3LIB_SRC}/w3fi92.f - ${W3LIB_SRC}/w3fp11.f - ${W3LIB_SRC}/w3fp12.f - ${W3LIB_SRC}/w3fp13.f - ${W3LIB_SRC}/w3fs13.f - ${W3LIB_SRC}/w3fs15.f - ${W3LIB_SRC}/w3fs21.f - ${W3LIB_SRC}/w3fs26.f - ${W3LIB_SRC}/w3ft32.f - ${W3LIB_SRC}/w3kind.f - ${W3LIB_SRC}/w3locdat.f - ${W3LIB_SRC}/w3movdat.f - ${W3LIB_SRC}/w3nogds.f - ${W3LIB_SRC}/w3pradat.f - ${W3LIB_SRC}/w3reddat.f - ${W3LIB_SRC}/w3tagb.f - ${W3LIB_SRC}/w3trnarg.f - ${W3LIB_SRC}/w3unpk77.f - ${W3LIB_SRC}/w3utcdat.f - ${W3LIB_SRC}/w3valdat.f - ${W3LIB_SRC}/w3ymdh4.f - ${W3LIB_SRC}/xmovex.f - ${W3LIB_SRC}/xstore.f -) - -#set Fortran compiler flags -if (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - #set(f_flags -fno-range-check -O3 -DLINUX) - set(f_flags -O0 -g -fdefault-real-8 -fno-range-check -ffixed-form -fPIC) -elseif (${CMAKE_Fortran_COMPILER_ID} MATCHES "Intel") - set(f_flags -O0 -g -r8 -fixed -fPIC) -elseif (${CMAKE_Fortran_COMPILER_ID} MATCHES "PGI") - set(f_flags -O0 -g -r8 -Mfixed -fPIC) -else (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - message ("CMAKE_Fortran_COMPILER full path: " ${CMAKE_Fortran_COMPILER}) - message ("Fortran compiler: " ${CMAKE_Fortran_COMPILER_ID}) - message (FATAL_ERROR "This library has only been compiled with gfortran, pgf90 and ifort. If another compiler is needed, the appropriate flags must be added in ${W3LIB_SRC}/CMakeLists.txt") -endif (${CMAKE_Fortran_COMPILER_ID} MATCHES "GNU") - -#set C compiler flags -set(c_flags -O3 -fPIC) - -#add OpenMP -set(c_flags ${c_flags} ${OpenMP_C_FLAGS}) -set(f_flags ${f_flags} ${OpenMP_Fortran_FLAGS}) - -if (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") - set(c_flags ${c_flags} -DMACOSX) -elseif (${CMAKE_SYSTEM_NAME} MATCHES "Linux") - set(c_flags ${c_flags} -DLINUX) -else (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") - message (FATAL_ERROR "This library has only been compiled on Linux and Darwin platforms. If another platform is needed, the appropriate flags must be added in ${W3LIB_SRC}/CMakeLists.txt") -endif (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") - -if(${CMAKE_VERSION} LESS 3.3) - file(GLOB f_files *.f) - string (REPLACE ";" " " f_flags_str "${f_flags}") - set(CMAKE_Fortran_FLAGS "${f_flags_str}") - file(GLOB c_files *.c) - string (REPLACE ";" " " c_flags_str "${c_flags}") - set(CMAKE_C_FLAGS "${c_flags_str}") -else(${CMAKE_VERSION} LESS 3.3) - add_compile_options("$<$:${f_flags}>") - add_compile_options("$<$:${c_flags}>") -endif (${CMAKE_VERSION} LESS 3.3) - -ADD_LIBRARY(w3 STATIC ${W3_source_code}) diff --git a/external/w3nco/v2.0.6/src/Makefile b/external/w3nco/v2.0.6/src/Makefile deleted file mode 100644 index 276308cbb..000000000 --- a/external/w3nco/v2.0.6/src/Makefile +++ /dev/null @@ -1,27 +0,0 @@ -# libsrc/w3nco makefile template -# -# Build Double Precision (Size of Real 8-byte and default Integer) version -# of libw3nco_d.a -# -# -include ../../../../macros.make - -FC = $(FCserial) -LIB = ../../../../libw3nco_d.a -FFLAGS = $(W3NCO_FFLAGS) -AFLAGS = $(W3NCO_ARFLAGS) -CFLAGS = $(W3NCO_CFLAGS) -SRCS = $(wildcard *.f *.c) -OBJS = $(addsuffix .o, $(basename $(SRCS))) - -%.o: %.f - $(FC) -c $(FFLAGS) $< - -%.o: %.c - $(CC) -c $(CFLAGS) $< - -$(LIB): $(OBJS) - ar $(AFLAGS) $@ $^ - -clean: - $(RM) *.o *.mod $(LIB) diff --git a/external/w3nco/v2.0.6/src/aea.f b/external/w3nco/v2.0.6/src/aea.f deleted file mode 100644 index f0361fdde..000000000 --- a/external/w3nco/v2.0.6/src/aea.f +++ /dev/null @@ -1,117 +0,0 @@ - SUBROUTINE AEA (IA, IE, NC ) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AEA ASCII TO EBCDIC, OR EBCDIC TO ASCII -C PRGMMR: DESMARAIS ORG: W342 DATE: 82-11-29 -C -C ABSTRACT: CONVERT ASCII TO EBCDIC, OR EBCDIC TO ASCII BY CHARACTER. -C THIS SUBROUTINE CAN BE REPLACED BY CRAY UTILITY SUBROUTINES -C USCCTC AND USCCTT. SEE MANUAL SR-2079 PAGE 3-15. CRAY UTILITY TR -C CAN ALSO BE USED FOR ASCII, EBCDIC CONVERSION. SEE MANUAL SR-2079 -C PAGE 9-35. -C -C PROGRAM HISTORY LOG: -C 82-11-29 DESMARAIS -C 88-03-31 R.E.JONES CHANGE LOGIC SO IT WORKS LIKE A -C IBM370 TRANSLATE INSTRUCTION. -C 88-08-22 R.E.JONES CHANGES FOR MICROSOFT FORTRAN 4.10 -C 88-09-04 R.E.JONES CHANGE TABLES TO 128 CHARACTER SET -C 90-01-31 R.E.JONES CONVERT TO CRAY CFT77 FORTRAN -C CRAY DOES NOT ALLOW CHAR*1 TO BE SET TO HEX -C 98-12-21 Gilbert Replaced Function ICHAR with mova2i. -C -C USAGE: CALL AEA (IA, IE, NC) -C INPUT ARGUMENT LIST: -C IA - CHARACTER*1 ARRAY OF ASCII DATA IF NC < 0 -C IE - CHARACTER*1 ARRAY OF EBCDIC DATA IF NC > 0 -C NC - INTEGER, CONTAINS CHARACTER COUNT TO CONVERT.... -C IF NC .LT. 0, CONVERT ASCII TO EBCDIC -C IF NC .GT. 0, CONVERT EBCDIC TO ASCII -C -C OUTPUT ARGUMENT LIST: -C IA - CHARACTER*1 ARRAY OF ASCII DATA IF NC > 0 -C IE - CHARACTER*1 ARRAY OF EBCDIC DATA IF NC < 0 -C -C REMARKS: SOFTWARE VERSION OF IBM370 TRANSLATE INSTRUCTION, BY -C CHANGING THE TWO TABLES WE COULD DO A 64, 96, 128 ASCII -C CHARACTER SET, CHANGE LOWER CASE TO UPPER, ETC. -C AEA CONVERTS DATA AT A RATE OF 1.5 MILLION CHARACTERS PER SEC. -C CRAY UTILITY USCCTI CONVERT IBM EBCDIC TO ASCII -C CRAY UTILITY USCCTC CONVERT ASCII TO IBM EBCDIC -C THEY CONVERT DATA AT A RATE OF 2.1 MILLION CHARACTERS PER SEC. -C CRAY UTILITY TR WILL ALSO DO A ASCII, EBCDIC CONVERSION. -C TR CONVERT DATA AT A RATE OF 5.4 MILLION CHARACTERS PER SEC. -C TR IS IN LIBRARY /USR/LIB/LIBCOS.A ADD TO SEGLDR CARD. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM SP -C -C$$$ -C*** ASCII CONTAINS ASCII CHARACTERS, AS PUNCHED ON IBM029 -C - INTEGER(8) IASCII(32) - INTEGER(8) IEBCDC(32) -C - CHARACTER*1 IA(*) - CHARACTER*1 IE(*) - CHARACTER*1 ASCII(0:255) - CHARACTER*1 EBCDIC(0:255) -C - EQUIVALENCE (IASCII(1),ASCII(0)) - EQUIVALENCE (IEBCDC(1),EBCDIC(0)) -C - DATA IASCII/ - & X'000102030009007F',X'0000000B0C0D0E0F', - & X'1011120000000000',X'1819000000000000', - & X'00001C000A001700',X'0000000000050607', - & X'00001600001E0004',X'000000001415001A', - & X'2000600000000000',X'0000602E3C282B00', - & X'2600000000000000',X'000021242A293B5E', - & X'2D2F000000000000',X'00007C2C255F3E3F', - & X'0000000000000000',X'00603A2340273D22', - & X'2061626364656667',X'6869202020202020', - & X'206A6B6C6D6E6F70',X'7172202020202020', - & X'207E737475767778',X'797A2020205B2020', - & X'0000000000000000',X'00000000005D0000', - & X'7B41424344454647',X'4849202020202020', - & X'7D4A4B4C4D4E4F50',X'5152202020202020', - & X'5C20535455565758',X'595A202020202020', - & X'3031323334353637',X'3839202020202020'/ -C -C*** EBCDIC CONTAINS HEX. REPRESENTATION OF EBCDIC CHARACTERS -C - DATA IEBCDC/ - & X'00010203372D2E2F',X'1605250B0C0D0E0F', - & X'101112003C3D3226',X'18193F2722003500', - & X'405A7F7B5B6C507D',X'4D5D5C4E6B604B61', - & X'F0F1F2F3F4F5F6F7',X'F8F97A5E4C7E6E6F', - & X'7CC1C2C3C4C5C6C7',X'C8C9D1D2D3D4D5D6', - & X'D7D8D9E2E3E4E5E6',X'E7E8E9ADE0BD5F6D', - & X'7981828384858687',X'8889919293949596', - & X'979899A2A3A4A5A6',X'A7A8A9C06AD0A107', - & 16*X'4040404040404040'/ -C - NUM = IABS(NC) -C - IF (NC .EQ. 0) RETURN -C - IF (NC .GT. 0) THEN -C -C*** CONVERT STRING ... EBCDIC TO ASCII, NUM CHARACTERS -C - DO 10 J = 1, NUM - IA(J) = ASCII(mova2i(IE(J))) - 10 CONTINUE -C - ELSE -C -C*** CONVERT STRING ... ASCII TO EBCDIC, NUM CHARACTERS -C - DO 20 J = 1, NUM - IE(J) = EBCDIC(mova2i(IA(J))) - 20 CONTINUE - END IF -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/errexit.f b/external/w3nco/v2.0.6/src/errexit.f deleted file mode 100644 index bc482fcbb..000000000 --- a/external/w3nco/v2.0.6/src/errexit.f +++ /dev/null @@ -1,33 +0,0 @@ - SUBROUTINE ERREXIT(IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: ERREXIT EXIT WITH A RETURN CODE -C PRGMMR: IREDELL ORG: NP23 DATE:1998-06-04 -C -C ABSTRACT: EXIT WITH A RETURN CODE -C -C PROGRAM HISTORY LOG: -C 1998-06-04 IREDELL -C 1999-01-26 Gilbert - changed to use XLF utility routine exit_(n) -C instead of exit(n). exit_(n) will return -C the proper value ( n must be 4 byte int ) -C to the sh/ksh shell status variable $? -C ( $status for csh ) on the IBM SP. -C -C USAGE: CALL ERREXIT(IRET) -C INPUT ARGUMENT LIST: -C IRET - INTEGER RETURN CODE -C -C SUBPROGRAMS CALLED: -C EXIT_ - EXITS FROM A FORTRAN PROGRAM -C -C ATTRIBUTES: -C LANGUAGE: XLF FORTRAN 90 -C MACHINE: IBM SP -C -C$$$ - INTEGER IRET - INTEGER(4) JRET - JRET=IRET - CALL exit(JRET) - END diff --git a/external/w3nco/v2.0.6/src/errmsg.f b/external/w3nco/v2.0.6/src/errmsg.f deleted file mode 100644 index c15a541ef..000000000 --- a/external/w3nco/v2.0.6/src/errmsg.f +++ /dev/null @@ -1,29 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE ERRMSG(CMSG) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: ERRMSG WRITE A MESSAGE TO STDERR -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 95-10-31 -C -C ABSTRACT: WRITE A MESSAGE TO STDERR. -C -C PROGRAM HISTORY LOG: -C 95-10-31 IREDELL -C -C USAGE: CALL ERRMSG(CMSG) -C INPUT ARGUMENTS: -C CMSG CHARACTER*(*) MESSAGE TO WRITE -C -C REMARKS: THIS IS A MACHINE-DEPENDENT SUBPROGRAM. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN -C MACHINE: CRAY -C -C$$$ - CHARACTER*(*) CMSG -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - WRITE(0,'(A)') CMSG -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/fparsei.f b/external/w3nco/v2.0.6/src/fparsei.f deleted file mode 100644 index dccf3aa15..000000000 --- a/external/w3nco/v2.0.6/src/fparsei.f +++ /dev/null @@ -1,39 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE FPARSEI(CARG,MARG,KARG) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FPARSER PARSE INTEGERS FROM A CHARACTER STRING -C PRGMMR: IREDELL ORG: NP23 DATE:1998-09-03 -C -C ABSTRACT: THIS SUBPROGRAM EXTRACTS INTEGERS FROM A FREE-FORMAT -C CHARACTER STRING. IT IS USEFUL FOR PARSING COMMAND ARGUMENTS. -C -C PROGRAM HISTORY LOG: -C 1998-09-03 IREDELL -C -C USAGE: CALL FPARSEI(CARG,MARG,KARG) -C -C INPUT ARGUMENT LIST: -C CARG - CHARACTER*(*) STRING OF ASCII DIGITS TO PARSE. -C INTEGERS MAY BE SEPARATED BY A COMMA OR BY BLANKS. -C MARG - INTEGER MAXIMUM NUMBER OF INTEGERS TO PARSE. -C -C OUTPUT ARGUMENT LIST: -C KARG - INTEGER (MARG) NUMBERS PARSED. -C (FROM 0 TO MARG VALUES MAY BE RETURNED.) -C -C REMARKS: -C TO DETERMINE THE ACTUAL NUMBER OF INTEGERS FOUND IN THE STRING, -C KARG SHOULD BE SET TO FILL VALUES BEFORE THE CALL TO FPARSEI AND -C THE NUMBER OF NON-FILL VALUES SHOULD BE COUNTED AFTER THE CALL. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - CHARACTER*(*) CARG - INTEGER KARG(MARG) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - READ(CARG,*,IOSTAT=IOS) KARG -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/w3nco/v2.0.6/src/fparser.f b/external/w3nco/v2.0.6/src/fparser.f deleted file mode 100644 index 85370ccfd..000000000 --- a/external/w3nco/v2.0.6/src/fparser.f +++ /dev/null @@ -1,39 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE FPARSER(CARG,MARG,RARG) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FPARSER PARSE REAL NUMBERS FROM A CHARACTER STRING -C PRGMMR: IREDELL ORG: NP23 DATE:1998-09-03 -C -C ABSTRACT: THIS SUBPROGRAM EXTRACTS REAL NUMBERS FROM A FREE-FORMAT -C CHARACTER STRING. IT IS USEFUL FOR PARSING COMMAND ARGUMENTS. -C -C PROGRAM HISTORY LOG: -C 1998-09-03 IREDELL -C -C USAGE: CALL FPARSER(CARG,MARG,RARG) -C -C INPUT ARGUMENT LIST: -C CARG - CHARACTER*(*) STRING OF ASCII DIGITS TO PARSE. -C REAL NUMBERS MAY BE SEPARATED BY A COMMA OR BY BLANKS. -C MARG - INTEGER MAXIMUM NUMBER OF REAL NUMBERS TO PARSE. -C -C OUTPUT ARGUMENT LIST: -C RARG - REAL (MARG) NUMBERS PARSED. -C (FROM 0 TO MARG VALUES MAY BE RETURNED.) -C -C REMARKS: -C TO DETERMINE THE ACTUAL NUMBER OF REAL NUMBERS FOUND IN THE STRING, -C RARG SHOULD BE SET TO FILL VALUES BEFORE THE CALL TO FPARSER AND -C THE NUMBER OF NON-FILL VALUES SHOULD BE COUNTED AFTER THE CALL. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ - CHARACTER*(*) CARG - REAL RARG(MARG) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - READ(CARG,*,IOSTAT=IOS) RARG -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/w3nco/v2.0.6/src/gbyte.f b/external/w3nco/v2.0.6/src/gbyte.f deleted file mode 100644 index 4e0e60dbe..000000000 --- a/external/w3nco/v2.0.6/src/gbyte.f +++ /dev/null @@ -1,108 +0,0 @@ - SUBROUTINE GBYTE(IPACKD,IUNPKD,NOFF,NBITS) -C -C THIS PROGRAM WRITTEN BY..... -C DR. ROBERT C. GAMMILL, CONSULTANT -C NATIONAL CENTER FOR ATMOSPHERIC RESEARCH -C MAY 1972 -C -C CHANGES FOR SiliconGraphics IRIS-4D/25 -C SiliconGraphics 3.3 FORTRAN 77 -C March 1991, RUSSELL E. JONES -C NATIONAL WEATHER SERVICE -C -C THIS IS THE FORTRAN VERSION OF GBYTE -C -C*********************************************************************** -C -C SUBROUTINE GBYTE (IPACKD,IUNPKD,NOFF,NBITS) -C -C PURPOSE TO UNPACK A BYTE INTO A TARGET WORD. THE -C UNPACKED BYTE IS RIGHT-JUSTIFIED IN THE -C TARGET WORD, AND THE REMAINDER OF THE -C WORD IS ZERO-FILLED. -C -C USAGE CALL GBYTE(IPACKD,IUNPKD,NOFF,NBITS) -C -C ARGUMENTS -C -C ON INPUT IPACKD -C THE WORD OR ARRAY CONTAINING THE BYTE TO BE -C UNPACKED. -C -C IUNPKD -C THE WORD WHICH WILL CONTAIN THE UNPACKED -C BYTE. -C -C NOFF -C THE NUMBER OF BITS TO SKIP, LEFT TO RIGHT, -C IN 'IPACKD' IN ORDER TO LOCATE THE BYTE -C TO BE UNPACKED. -C -C NBITS -C NUMBER OF BITS IN THE BYTE TO BE UNPACKED. -C MAXIMUM OF 64 BITS ON 64 BIT MACHINE, 32 -C BITS ON 32 BIT MACHINE. -C -C ON OUTPUT IUNPKD -C CONTAINS THE REQUESTED UNPACKED BYTE. -C*********************************************************************** - - INTEGER IPACKD(*) - INTEGER IUNPKD - INTEGER MASKS(64) -C - SAVE -C - DATA IFIRST/1/ - IF(IFIRST.EQ.1) THEN - CALL W3FI01(LW) - NBITSW = 8 * LW - JSHIFT = -1 * NINT(ALOG(FLOAT(NBITSW)) / ALOG(2.0)) - MASKS(1) = 1 - DO I=2,NBITSW-1 - MASKS(I) = 2 * MASKS(I-1) + 1 - ENDDO - MASKS(NBITSW) = -1 - IFIRST = 0 - ENDIF -C -C NBITS MUST BE LESS THAN OR EQUAL TO NBITSW -C - ICON = NBITSW - NBITS - IF (ICON.LT.0) RETURN - MASK = MASKS(NBITS) -C -C INDEX TELLS HOW MANY WORDS INTO THE ARRAY 'IPACKD' THE NEXT BYTE -C APPEARS. -C - INDEX = ISHFT(NOFF,JSHIFT) -C -C II TELLS HOW MANY BITS THE BYTE IS FROM THE LEFT SIDE OF THE WORD. -C - II = MOD(NOFF,NBITSW) -C -C MOVER SPECIFIES HOW FAR TO THE RIGHT NBITS MUST BE MOVED IN ORDER -C -C TO BE RIGHT ADJUSTED. -C - MOVER = ICON - II -C - IF (MOVER.GT.0) THEN - IUNPKD = IAND(ISHFT(IPACKD(INDEX+1),-MOVER),MASK) -C -C THE BYTE IS SPLIT ACROSS A WORD BREAK. -C - ELSE IF (MOVER.LT.0) THEN - MOVEL = - MOVER - MOVER = NBITSW - MOVEL - IUNPKD = IAND(IOR(ISHFT(IPACKD(INDEX+1),MOVEL), - & ISHFT(IPACKD(INDEX+2),-MOVER)),MASK) -C -C THE BYTE IS ALREADY RIGHT ADJUSTED. -C - ELSE - IUNPKD = IAND(IPACKD(INDEX+1),MASK) - ENDIF -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/gbytec.f b/external/w3nco/v2.0.6/src/gbytec.f deleted file mode 100644 index 222b0e504..000000000 --- a/external/w3nco/v2.0.6/src/gbytec.f +++ /dev/null @@ -1,6 +0,0 @@ - SUBROUTINE GBYTEC(IN,IOUT,ISKIP,NBYTE) - character*1 in(*) - integer iout(*) - CALL GBYTESC(IN,IOUT,ISKIP,NBYTE,0,1) - RETURN - END diff --git a/external/w3nco/v2.0.6/src/gbytes.f b/external/w3nco/v2.0.6/src/gbytes.f deleted file mode 100644 index 1551117d4..000000000 --- a/external/w3nco/v2.0.6/src/gbytes.f +++ /dev/null @@ -1,144 +0,0 @@ - SUBROUTINE GBYTES(IPACKD,IUNPKD,NOFF,NBITS,ISKIP,ITER) -C -C THIS PROGRAM WRITTEN BY..... -C DR. ROBERT C. GAMMILL, CONSULTANT -C NATIONAL CENTER FOR ATMOSPHERIC RESEARCH -C MAY 1972 -C -C CHANGES FOR SiliconGraphics IRIS-4D/25 -C SiliconGraphics 3.3 FORTRAN 77 -C MARCH 1991, RUSSELL E. JONES -C NATIONAL WEATHER SERVICE -C -C THIS IS THE FORTRAN VERSION OF GBYTES. -C -C*********************************************************************** -C -C SUBROUTINE GBYTES (IPACKD,IUNPKD,NOFF,NBITS,ISKIP,ITER) -C -C PURPOSE TO UNPACK A SERIES OF BYTES INTO A TARGET -C ARRAY. EACH UNPACKED BYTE IS RIGHT-JUSTIFIED -C IN ITS TARGET WORD, AND THE REMAINDER OF THE -C WORD IS ZERO-FILLED. -C -C USAGE CALL GBYTES (IPACKD,IUNPKD,NOFF,NBITS,NSKIP, -C ITER) -C -C ARGUMENTS -C ON INPUT IPACKD -C THE WORD OR ARRAY CONTAINING THE PACKED -C BYTES. -C -C IUNPKD -C THE ARRAY WHICH WILL CONTAIN THE UNPACKED -C BYTES. -C -C NOFF -C THE INITIAL NUMBER OF BITS TO SKIP, LEFT -C TO RIGHT, IN 'IPACKD' IN ORDER TO LOCATE -C THE FIRST BYTE TO UNPACK. -C -C NBITS -C NUMBER OF BITS IN THE BYTE TO BE UNPACKED. -C MAXIMUM OF 64 BITS ON 64 BIT MACHINE, 32 -C BITS ON 32 BIT MACHINE. -C -C ISKIP -C THE NUMBER OF BITS TO SKIP BETWEEN EACH BYTE -C IN 'IPACKD' IN ORDER TO LOCATE THE NEXT BYTE -C TO BE UNPACKED. -C -C ITER -C THE NUMBER OF BYTES TO BE UNPACKED. -C -C ARGUMENTS -C ON OUTPUT IUNPKD -C CONTAINS THE REQUESTED UNPACKED BYTES. -C*********************************************************************** - - INTEGER IPACKD(*) - - INTEGER IUNPKD(*) - INTEGER MASKS(64) -C - SAVE -C - DATA IFIRST/1/ - IF(IFIRST.EQ.1) THEN - CALL W3FI01(LW) - NBITSW = 8 * LW - JSHIFT = -1 * NINT(ALOG(FLOAT(NBITSW)) / ALOG(2.0)) - MASKS(1) = 1 - DO I=2,NBITSW-1 - MASKS(I) = 2 * MASKS(I-1) + 1 - ENDDO - MASKS(NBITSW) = -1 - IFIRST = 0 - ENDIF -C -C NBITS MUST BE LESS THAN OR EQUAL TO NBITSW -C - ICON = NBITSW - NBITS - IF (ICON.LT.0) RETURN - MASK = MASKS(NBITS) -C -C INDEX TELLS HOW MANY WORDS INTO THE ARRAY 'IPACKD' THE NEXT BYTE -C APPEARS. -C - INDEX = ISHFT(NOFF,JSHIFT) -C -C II TELLS HOW MANY BITS THE BYTE IS FROM THE LEFT SIDE OF THE WORD. -C - II = MOD(NOFF,NBITSW) -C -C ISTEP IS THE DISTANCE IN BITS FROM THE START OF ONE BYTE TO THE NEXT. -C - ISTEP = NBITS + ISKIP -C -C IWORDS TELLS HOW MANY WORDS TO SKIP FROM ONE BYTE TO THE NEXT. -C - IWORDS = ISTEP / NBITSW -C -C IBITS TELLS HOW MANY BITS TO SKIP AFTER SKIPPING IWORDS. -C - IBITS = MOD(ISTEP,NBITSW) -C - DO 10 I = 1,ITER -C -C MOVER SPECIFIES HOW FAR TO THE RIGHT A BYTE MUST BE MOVED IN ORDER -C -C TO BE RIGHT ADJUSTED. -C - MOVER = ICON - II -C -C THE BYTE IS SPLIT ACROSS A WORD BREAK. -C - IF (MOVER.LT.0) THEN - MOVEL = - MOVER - MOVER = NBITSW - MOVEL - IUNPKD(I) = IAND(IOR(ISHFT(IPACKD(INDEX+1),MOVEL), - & ISHFT(IPACKD(INDEX+2),-MOVER)),MASK) -C -C RIGHT ADJUST THE BYTE. -C - ELSE IF (MOVER.GT.0) THEN - IUNPKD(I) = IAND(ISHFT(IPACKD(INDEX+1),-MOVER),MASK) -C -C THE BYTE IS ALREADY RIGHT ADJUSTED. -C - ELSE - IUNPKD(I) = IAND(IPACKD(INDEX+1),MASK) - ENDIF -C -C INCREMENT II AND INDEX. -C - II = II + IBITS - INDEX = INDEX + IWORDS - IF (II.GE.NBITSW) THEN - II = II - NBITSW - INDEX = INDEX + 1 - ENDIF -C - 10 CONTINUE - RETURN - END diff --git a/external/w3nco/v2.0.6/src/gbytesc.f b/external/w3nco/v2.0.6/src/gbytesc.f deleted file mode 100644 index 589b4da8f..000000000 --- a/external/w3nco/v2.0.6/src/gbytesc.f +++ /dev/null @@ -1,51 +0,0 @@ - SUBROUTINE GBYTESC(IN,IOUT,ISKIP,NBYTE,NSKIP,N) -C Get bytes - unpack bits: Extract arbitrary size values from a -C packed bit string, right justifying each value in the unpacked -C array. -C IN = character*1 array input -C IOUT = unpacked array output -C ISKIP = initial number of bits to skip -C NBYTE = number of bits to take -C NSKIP = additional number of bits to skip on each iteration -C N = number of iterations -C v1.1 -C - character*1 in(*) - integer iout(*) - integer ones(8), tbit, bitcnt - save ones - data ones/1,3,7,15,31,63,127,255/ - -c nbit is the start position of the field in bits - nbit = iskip - do i = 1, n - bitcnt = nbyte - index=nbit/8+1 - ibit=mod(nbit,8) - nbit = nbit + nbyte + nskip - -c first byte - tbit = min(bitcnt,8-ibit) - itmp = iand(mova2i(in(index)),ones(8-ibit)) - if (tbit.ne.8-ibit) itmp = ishft(itmp,tbit-8+ibit) - index = index + 1 - bitcnt = bitcnt - tbit - -c now transfer whole bytes - do while (bitcnt.ge.8) - itmp = ior(ishft(itmp,8),mova2i(in(index))) - bitcnt = bitcnt - 8 - index = index + 1 - enddo - -c get data from last byte - if (bitcnt.gt.0) then - itmp = ior(ishft(itmp,bitcnt),iand(ishft(mova2i(in(index)), - 1 -(8-bitcnt)),ones(bitcnt))) - endif - - iout(i) = itmp - enddo - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getbit.f b/external/w3nco/v2.0.6/src/getbit.f deleted file mode 100644 index 3e4aea6fc..000000000 --- a/external/w3nco/v2.0.6/src/getbit.f +++ /dev/null @@ -1,87 +0,0 @@ - SUBROUTINE GETBIT(IBM,IBS,IDS,LEN,MG,G,GROUND,GMIN,GMAX,NBIT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETBIT COMPUTE NUMBER OF BITS AND ROUND FIELD. -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: THE NUMBER OF BITS REQUIRED TO PACK A GIVEN FIELD -C FOR PARTICULAR BINARY AND DECIMAL SCALINGS IS COMPUTED. -C THE FIELD IS ROUNDED OFF TO THE DECIMAL SCALING FOR PACKING. -C THE MINIMUM AND MAXIMUM ROUNDED FIELD VALUES ARE ALSO RETURNED. -C GRIB BITMAP MASKING FOR VALID DATA IS OPTIONALLY USED. -C -C PROGRAM HISTORY LOG: -C 96-09-16 IREDELL -C -C USAGE: CALL GTBITS(IBM,IBS,IDS,LEN,MG,G,GMIN,GMAX,NBIT) -C INPUT ARGUMENT LIST: -C IBM - INTEGER BITMAP FLAG (=0 FOR NO BITMAP) -C IBS - INTEGER BINARY SCALING -C (E.G. IBS=3 TO ROUND FIELD TO NEAREST EIGHTH VALUE) -C IDS - INTEGER DECIMAL SCALING -C (E.G. IDS=3 TO ROUND FIELD TO NEAREST MILLI-VALUE) -C (NOTE THAT IDS AND IBS CAN BOTH BE NONZERO, -C E.G. IDS=1 AND IBS=1 ROUNDS TO THE NEAREST TWENTIETH) -C LEN - INTEGER LENGTH OF THE FIELD AND BITMAP -C MG - INTEGER (LEN) BITMAP IF IBM=1 (0 TO SKIP, 1 TO KEEP) -C G - REAL (LEN) FIELD -C -C OUTPUT ARGUMENT LIST: -C GROUND - REAL (LEN) FIELD ROUNDED TO DECIMAL AND BINARY SCALING -C (SET TO ZERO WHERE BITMAP IS 0 IF IBM=1) -C GMIN - REAL MINIMUM VALID ROUNDED FIELD VALUE -C GMAX - REAL MAXIMUM VALID ROUNDED FIELD VALUE -C NBIT - INTEGER NUMBER OF BITS TO PACK -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - DIMENSION MG(LEN),G(LEN),GROUND(LEN) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C ROUND FIELD AND DETERMINE EXTREMES WHERE BITMAP IS ON - S=2.**IBS*10.**IDS - IF(IBM.EQ.0) THEN - GROUND(1)=NINT(G(1)*S)/S - GMAX=GROUND(1) - GMIN=GROUND(1) - DO I=2,LEN - GROUND(I)=NINT(G(I)*S)/S - GMAX=MAX(GMAX,GROUND(I)) - GMIN=MIN(GMIN,GROUND(I)) - ENDDO - ELSE - I1=1 - DOWHILE(I1.LE.LEN.AND.MG(I1).EQ.0) - I1=I1+1 - ENDDO - IF(I1.LE.LEN) THEN - DO I=1,I1-1 - GROUND(I)=0. - ENDDO - GROUND(I1)=NINT(G(I1)*S)/S - GMAX=GROUND(I1) - GMIN=GROUND(I1) - DO I=I1+1,LEN - IF(MG(I).NE.0) THEN - GROUND(I)=NINT(G(I)*S)/S - GMAX=MAX(GMAX,GROUND(I)) - GMIN=MIN(GMIN,GROUND(I)) - ELSE - GROUND(I)=0. - ENDIF - ENDDO - ELSE - DO I=1,LEN - GROUND(I)=0. - ENDDO - GMAX=0. - GMIN=0. - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE NUMBER OF BITS - NBIT=LOG((GMAX-GMIN)*S+0.9)/LOG(2.)+1. -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgb.f b/external/w3nco/v2.0.6/src/getgb.f deleted file mode 100644 index fac9c3dfb..000000000 --- a/external/w3nco/v2.0.6/src/getgb.f +++ /dev/null @@ -1,213 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGB(LUGB,LUGI,JF,J,JPDS,JGDS, - & KF,K,KPDS,KGDS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGB FINDS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND AND UNPACK A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C (THE INDEX BUFFER IS SAVED FOR USE BY FUTURE PROSPECTIVE CALLS.) -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE AND UNPACKED. ITS MESSAGE NUMBER IS RETURNED ALONG WITH -C THE UNPACKED PDS AND GDS PARAMETERS, THE UNPACKED BITMAP (IF ANY), -C AND THE UNPACKED DATA. IF THE GRIB MESSAGE IS NOT FOUND, THEN THE -C RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGB(LUGB,LUGI,JF,J,JPDS,JGDS, -C & KF,K,KPDS,KGDS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JF INTEGER MAXIMUM NUMBER OF DATA POINTS TO UNPACK -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C OUTPUT ARGUMENTS: -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF DATA POINTS GREATER THAN JF -C 99 REQUEST NOT FOUND -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C GETGBM FIND AND UNPACK GRIB MESSAGE -C -C REMARKS: IN ORDER TO UNPACK GRIB FROM A MULTIPROCESSING ENVIRONMENT -C WHERE EACH PROCESSOR IS ATTEMPTING TO READ FROM ITS OWN PAIR OF -C LOGICAL UNITS, ONE MUST DIRECTLY CALL SUBPROGRAM GETGBM AS BELOW, -C ALLOCATING A PRIVATE COPY OF CBUF, NLEN AND NNUM TO EACH PROCESSOR. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),KPDS(200),KGDS(200) - LOGICAL*1 LB(JF) - REAL F(JF) - PARAMETER(MBUF=256*1024) - CHARACTER CBUF(MBUF) - SAVE CBUF,NLEN,NNUM,MNUM - DATA LUX/0/ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE WHETHER INDEX BUFFER NEEDS TO BE INITIALIZED - IF(LUGI.GT.0.AND.(J.LT.0.OR.LUGI.NE.LUX)) THEN - LUX=LUGI - JJ=MIN(J,-1-J) - ELSEIF(LUGI.LE.0.AND.(J.LT.0.OR.LUGB.NE.LUX)) THEN - LUX=LUGB - JJ=MIN(J,-1-J) - ELSE - JJ=J - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FIND AND UNPACK GRIB MESSAGE - CALL GETGBM(LUGB,LUGI,JF,JJ,JPDS,JGDS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KF,K,KPDS,KGDS,LB,F,IRET) - IF(IRET.EQ.96) LUX=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgb1.f b/external/w3nco/v2.0.6/src/getgb1.f deleted file mode 100644 index 418a98467..000000000 --- a/external/w3nco/v2.0.6/src/getgb1.f +++ /dev/null @@ -1,199 +0,0 @@ - SUBROUTINE GETGB1(LUGB,LUGI,JF,J,JPDS,JGDS, - & GRIB,KF,K,KPDS,KGDS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGB1 FINDS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND AND UNPACK A GRIB MESSAGE. -C READ AN ASSOCIATED GRIB INDEX FILE (UNLESS IT ALREADY WAS READ). -C FIND IN THE INDEX FILE A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE AND UNPACKED. ITS MESSAGE NUMBER IS RETURNED ALONG WITH -C THE UNPACKED PDS AND GDS PARAMETERS, THE UNPACKED BITMAP (IF ANY), -C AND THE UNPACKED DATA. IF THE GRIB MESSAGE IS NOT FOUND, THEN THE -C RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-05-10 R.E.JONES ADD ONE MORE PARAMETER TO GETGB AND -C CHANGE NAME TO GETGB1 -C -C USAGE: CALL GETGB1(LUGB,LUGI,JF,J,JPDS,JGDS, -C & GRIB,KF,K,KPDS,KGDS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB LOGICAL UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI LOGICAL UNIT OF THE UNBLOCKED GRIB INDEX FILE -C JF INTEGER MAXIMUM NUMBER OF DATA POINTS TO UNPACK -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO REOPEN INDEX FILE AND SEARCH FROM BEGINNING) -C JPDS INTEGER (25) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C LOOK IN DOC BLOCK OF W3FI63 FOR ARRAY KPDS -C FOR LIST OF ORDER OF UNPACKED PDS VALUES. IN -C MOST CASES YOU ONLY NEED TO SET 4 OR 5 VALUES -C TO PICK UP RECORD. -C JGDS INTEGER (22) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C OUTPUT ARGUMENTS: -C GRIB GRIB DATA ARRAY BEFORE IT IS UNPACKED -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (25) UNPACKED PDS PARAMETERS -C KGDS INTEGER (22) UNPACKED GDS PARAMETERS -C LB LOGICAL (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF DATA POINTS GREATER THAN JF -C 99 REQUEST NOT FOUND -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C BAREAD BYTE-ADDRESSABLE READ -C GBYTE UNPACK BYTES -C FI632 UNPACK PDS -C FI633 UNPACK GDS -C W3FI63 UNPACK GRIB -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916/256, J916/2048 -C -C$$$ -C - PARAMETER (MBUF=8192*128) - PARAMETER (LPDS=23,LGDS=22) -C - INTEGER JPDS(25),JGDS(*),KPDS(25),KGDS(*) - INTEGER IPDSP(LPDS),JPDSP(LPDS),IGDSP(LGDS) - INTEGER JGDSP(LGDS) - INTEGER KPTR(20) -C - LOGICAL LB(*) -C - REAL F(*) -C - CHARACTER CBUF(MBUF) - CHARACTER*81 CHEAD(2) - CHARACTER*1 CPDS(28) - CHARACTER*1 CGDS(42) - CHARACTER*1 GRIB(*) -C -C SAVE LUX,NSKP,NLEN,NNUM,CBUF - SAVE -C - DATA LUX/0/ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ INDEX FILE - IF(J.LT.0.OR.LUGI.NE.LUX) THEN -C REWIND LUGI -C READ(LUGI,fmt='(2A81)',IOSTAT=IOS) CHEAD - CALL BAREAD(LUGI,0,162,ios,chead) - IF(IOS.EQ.162.AND.CHEAD(1)(42:47).EQ.'GB1IX1') THEN - LUX=0 - READ(CHEAD(2),'(8X,3I10,2X,A40)',IOSTAT=IOS) NSKP,NLEN,NNUM - IF(IOS.EQ.0) THEN - NBUF=NNUM*NLEN - IF(NBUF.GT.MBUF) THEN - PRINT *,'GETGB1: INCREASE BUFFER FROM ',MBUF,' TO ',NBUF - NNUM=MBUF/NLEN - NBUF=NNUM*NLEN - ENDIF - CALL BAREAD(LUGI,NSKP,NBUF,LBUF,CBUF) - IF(LBUF.EQ.NBUF) THEN - LUX=LUGI - J=MAX(J,0) - ENDIF - ENDIF - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH FOR REQUEST - LGRIB=0 - KJ=J - K=J - KF=0 - IF(J.GE.0.AND.LUGI.EQ.LUX) THEN - LPDSP=0 - DO I=1,LPDS - IF(JPDS(I).NE.-1) THEN - LPDSP=LPDSP+1 - IPDSP(LPDSP)=I - JPDSP(LPDSP)=JPDS(I) - ENDIF - ENDDO - LGDSP=0 - IF(JPDS(3).EQ.255) THEN - DO I=1,LGDS - IF(JGDS(I).NE.-1) THEN - LGDSP=LGDSP+1 - IGDSP(LGDSP)=I - JGDSP(LGDSP)=JGDS(I) - ENDIF - ENDDO - ENDIF - IRET=99 - DOWHILE(LGRIB.EQ.0.AND.KJ.LT.NNUM) - KJ=KJ+1 - LT=0 - IF(LPDSP.GT.0) THEN - CPDS=CBUF((KJ-1)*NLEN+26:(KJ-1)*NLEN+53) - KPTR=0 - CALL GBYTE(CBUF,KPTR(3),(KJ-1)*NLEN*8+25*8,3*8) - CALL FI632(CPDS,KPTR,KPDS,IRET) - DO I=1,LPDSP - IP=IPDSP(I) - LT=LT+ABS(JPDS(IP)-KPDS(IP)) - ENDDO - ENDIF - IF(LT.EQ.0.AND.LGDSP.GT.0) THEN - CGDS=CBUF((KJ-1)*NLEN+54:(KJ-1)*NLEN+95) - KPTR=0 - CALL FI633(CGDS,KPTR,KGDS,IRET) - DO I=1,LGDSP - IP=IGDSP(I) - LT=LT+ABS(JGDS(IP)-KGDS(IP)) - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND UNPACK GRIB DATA - IF(LT.EQ.0) THEN - CALL GBYTE(CBUF,LSKIP,(KJ-1)*NLEN*8,4*8) - CALL GBYTE(CBUF,LGRIB,(KJ-1)*NLEN*8+20*8,4*8) - CGDS=CBUF((KJ-1)*NLEN+54:(KJ-1)*NLEN+95) - KPTR=0 - CALL FI633(CGDS,KPTR,KGDS,IRET) -C BSM IF(LGRIB.LE.200+17*JF/8.AND.KGDS(2)*KGDS(3).LE.JF) THEN -C Change number of bits that can be handled to 25 - IF(LGRIB.LE.200+25*JF/8.AND.KGDS(2)*KGDS(3).LE.JF) THEN - CALL BAREAD(LUGB,LSKIP,LGRIB,LREAD,GRIB) - IF(LREAD.EQ.LGRIB) THEN - CALL W3FI63(GRIB,KPDS,KGDS,LB,F,KPTR,IRET) - IF(IRET.EQ.0) THEN - K=KJ - KF=KPTR(10) - ENDIF - ELSE - IRET=97 - ENDIF - ELSE - IRET=98 - ENDIF - ENDIF - ENDDO - ELSE - IRET=96 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgb1r.f b/external/w3nco/v2.0.6/src/getgb1r.f deleted file mode 100644 index fcf66cf98..000000000 --- a/external/w3nco/v2.0.6/src/getgb1r.f +++ /dev/null @@ -1,76 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGB1R(LUGB,LSKIP,LGRIB,KF,KPDS,KGDS,KENS,LB,F,NBITSS - + ,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGB1R READS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 95-10-31 -C -C ABSTRACT: READ AND UNPACK A GRIB MESSAGE. -C -C PROGRAM HISTORY LOG: -C 95-10-31 IREDELL -C 04-07-22 CHUANG ADD PACKING BIT NUMBER NBITSS IN THE ARGUMENT -C LIST BECAUSE ETA GRIB FILES NEED IT TO REPACK GRIB FILE -C USAGE: CALL -C GETGB1R(LUGB,LSKIP,LGRIB,KF,KPDS,KGDS,KENS,LB,F,,NBITSS,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LSKIP INTEGER NUMBER OF BYTES TO SKIP -C LGRIB INTEGER NUMBER OF BYTES TO READ -C OUTPUT ARGUMENTS: -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 97 ERROR READING GRIB FILE -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C BAREAD BYTE-ADDRESSABLE READ -C W3FI63 UNPACK GRIB -C PDSEUP UNPACK PDS EXTENSION -C -C REMARKS: THERE IS NO PROTECTION AGAINST UNPACKING TOO MUCH DATA. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C THIS SUBPROGRAM IS INTENDED FOR PRIVATE USE BY GETGB ROUTINES ONLY. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER KPDS(200),KGDS(200),KENS(200) - LOGICAL*1 LB(*) - REAL F(*) - INTEGER KPTR(200) - CHARACTER GRIB(LGRIB)*1 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ GRIB RECORD - CALL BAREAD(LUGB,LSKIP,LGRIB,LREAD,GRIB) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C UNPACK GRIB RECORD - IF(LREAD.EQ.LGRIB) THEN - CALL W3FI63(GRIB,KPDS,KGDS,LB,F,KPTR,IRET) - IF(IRET.EQ.0.AND.KPDS(23).EQ.2) THEN - CALL PDSEUP(KENS,KPROB,XPROB,KCLUST,KMEMBR,45,GRIB(9)) - ENDIF - ELSE - IRET=97 - ENDIF - NBITSS=KPTR(20) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C RETURN NUMBER OF POINTS - IF(IRET.EQ.0) THEN - KF=KPTR(10) - ELSE - KF=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgb1re.f b/external/w3nco/v2.0.6/src/getgb1re.f deleted file mode 100644 index 46ad99e17..000000000 --- a/external/w3nco/v2.0.6/src/getgb1re.f +++ /dev/null @@ -1,81 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGB1RE(LUGB,LSKIP,LGRIB,KF,KPDS,KGDS,KENS, - & KPROB,XPROB,KCLUST,KMEMBR,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGB1RE READS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 95-10-31 -C -C ABSTRACT: READ AND UNPACK A GRIB MESSAGE. -C -C PROGRAM HISTORY LOG: -C 95-10-31 IREDELL -C 97-02-11 Y.ZHU INCLUDED PROBABILITY AND CLUSTER ARGUMENTS -C -C USAGE: CALL GETGB1RE(LUGB,LSKIP,LGRIB,KF,KPDS,KGDS,KENS, -C & KPROB,XPROB,KCLUST,KMEMBR,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LSKIP INTEGER NUMBER OF BYTES TO SKIP -C LGRIB INTEGER NUMBER OF BYTES TO READ -C OUTPUT ARGUMENTS: -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C KPROB INTEGER (2) PROBABILITY ENSEMBLE PARMS -C XPROB REAL (2) PROBABILITY ENSEMBLE PARMS -C KCLUST INTEGER (16) CLUSTER ENSEMBLE PARMS -C KMEMBR INTEGER (8) CLUSTER ENSEMBLE PARMS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 97 ERROR READING GRIB FILE -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C BAREAD BYTE-ADDRESSABLE READ -C W3FI63 UNPACK GRIB -C PDSEUP UNPACK PDS EXTENSION -C -C REMARKS: THERE IS NO PROTECTION AGAINST UNPACKING TOO MUCH DATA. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C THIS SUBPROGRAM IS INTENDED FOR PRIVATE USE BY GETGB ROUTINES ONLY. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER KPDS(200),KGDS(200),KENS(200) - INTEGER KPROB(2),KCLUST(16),KMEMBR(80) - REAL XPROB(2) - LOGICAL*1 LB(*) - REAL F(*) - INTEGER KPTR(200) - CHARACTER GRIB(LGRIB)*1 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ GRIB RECORD - CALL BAREAD(LUGB,LSKIP,LGRIB,LREAD,GRIB) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C UNPACK GRIB RECORD - IF(LREAD.EQ.LGRIB) THEN - CALL W3FI63(GRIB,KPDS,KGDS,LB,F,KPTR,IRET) - IF(IRET.EQ.0.AND.KPDS(23).EQ.2) THEN - CALL PDSEUP(KENS,KPROB,XPROB,KCLUST,KMEMBR,86,GRIB(9)) - ENDIF - ELSE - IRET=97 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C RETURN NUMBER OF POINTS - IF(IRET.EQ.0) THEN - KF=KPTR(10) - ELSE - KF=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgb1s.f b/external/w3nco/v2.0.6/src/getgb1s.f deleted file mode 100644 index ec54d7e4c..000000000 --- a/external/w3nco/v2.0.6/src/getgb1s.f +++ /dev/null @@ -1,185 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGB1S(CBUF,NLEN,NNUM,J,JPDS,JGDS,JENS, - & K,KPDS,KGDS,KENS,LSKIP,LGRIB,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGB1S FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 95-10-31 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C FIND IN THE INDEX FILE A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C -C PROGRAM HISTORY LOG: -C 95-10-31 IREDELL -C 2001-06-05 IREDELL APPLY LINUX PORT BY EBISUZAKI -C -C USAGE: CALL GETGB1S(CBUF,NLEN,NNUM,J,JPDS,JGDS,JENS, -C & K,KPDS,KGDS,KENS,LSKIP,LGRIB,IRET) -C INPUT ARGUMENTS: -C CBUF CHARACTER*1 (NLEN*NNUM) BUFFER CONTAINING INDEX DATA -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C OUTPUT ARGUMENTS: -C K INTEGER MESSAGE NUMBER FOUND -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C LSKIP INTEGER NUMBER OF BYTES TO SKIP -C LGRIB INTEGER NUMBER OF BYTES TO READ -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 1 REQUEST NOT FOUND -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C THIS SUBPROGRAM IS INTENDED FOR PRIVATE USE BY GETGB ROUTINES ONLY. -C -C SUBPROGRAMS CALLED: -C GBYTEC UNPACK BYTES -C FI632 UNPACK PDS -C FI633 UNPACK GDS -C PDSEUP UNPACK PDS EXTENSION -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - CHARACTER CBUF(NLEN*NNUM) - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - PARAMETER(LPDS=23,LGDS=22,LENS=5) ! ACTUAL SEARCH RANGES - CHARACTER CPDS(400)*1,CGDS(400)*1 - INTEGER KPTR(200) - INTEGER IPDSP(LPDS),JPDSP(LPDS) - INTEGER IGDSP(LGDS),JGDSP(LGDS) - INTEGER IENSP(LENS),JENSP(LENS) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPRESS REQUEST LISTS - K=J - LSKIP=0 - LGRIB=0 - IRET=1 -C COMPRESS PDS REQUEST - LPDSP=0 - DO I=1,LPDS - IF(JPDS(I).NE.-1) THEN - LPDSP=LPDSP+1 - IPDSP(LPDSP)=I - JPDSP(LPDSP)=JPDS(I) - ENDIF - ENDDO -C COMPRESS GDS REQUEST - LGDSP=0 - IF(JPDS(3).EQ.255) THEN - DO I=1,LGDS - IF(JGDS(I).NE.-1) THEN - LGDSP=LGDSP+1 - IGDSP(LGDSP)=I - JGDSP(LGDSP)=JGDS(I) - ENDIF - ENDDO - ENDIF -C COMPRESS ENS REQUEST - LENSP=0 - IF(JPDS(23).EQ.2) THEN - DO I=1,LENS - IF(JENS(I).NE.-1) THEN - LENSP=LENSP+1 - IENSP(LENSP)=I - JENSP(LENSP)=JENS(I) - ENDIF - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH FOR REQUEST - DOWHILE(IRET.NE.0.AND.K.LT.NNUM) - K=K+1 - LT=0 -C SEARCH FOR PDS REQUEST - IF(LPDSP.GT.0) THEN - CPDS=CHAR(0) - CPDS(1:28)=CBUF((K-1)*NLEN+26:(K-1)*NLEN+53) - NLESS=MAX(184-NLEN,0) - CPDS(29:40-NLESS)=CBUF((K-1)*NLEN+173:(K-1)*NLEN+184-NLESS) - KPTR=0 - CALL GBYTEC(CBUF,KPTR(3),(K-1)*NLEN*8+25*8,3*8) - KPDS(18)=1 - CALL GBYTEC(CPDS,KPDS(4),7*8,8) - CALL FI632(CPDS,KPTR,KPDS,KRET) - DO I=1,LPDSP - IP=IPDSP(I) - LT=LT+ABS(JPDS(IP)-KPDS(IP)) - ENDDO - ENDIF -C SEARCH FOR GDS REQUEST - IF(LT.EQ.0.AND.LGDSP.GT.0) THEN - CGDS=CHAR(0) - CGDS(1:42)=CBUF((K-1)*NLEN+54:(K-1)*NLEN+95) - NLESS=MAX(320-NLEN,0) - CGDS(43:178-NLESS)=CBUF((K-1)*NLEN+185:(K-1)*NLEN+320-NLESS) - KPTR=0 - CALL FI633(CGDS,KPTR,KGDS,KRET) - DO I=1,LGDSP - IP=IGDSP(I) - LT=LT+ABS(JGDS(IP)-KGDS(IP)) - ENDDO - ENDIF -C SEARCH FOR ENS REQUEST - IF(LT.EQ.0.AND.LENSP.GT.0) THEN - NLESS=MAX(172-NLEN,0) - CPDS(41:100-NLESS)=CBUF((K-1)*NLEN+113:(K-1)*NLEN+172-NLESS) - CALL PDSEUP(KENS,KPROB,XPROB,KCLUST,KMEMBR,45,CPDS) - DO I=1,LENSP - IP=IENSP(I) - LT=LT+ABS(JENS(IP)-KENS(IP)) - ENDDO - ENDIF -C RETURN IF REQUEST IS FOUND - IF(LT.EQ.0) THEN - CALL GBYTEC(CBUF,LSKIP,(K-1)*NLEN*8,4*8) - CALL GBYTEC(CBUF,LGRIB,(K-1)*NLEN*8+20*8,4*8) - IF(LPDSP.EQ.0) THEN - CPDS=CHAR(0) - CPDS(1:28)=CBUF((K-1)*NLEN+26:(K-1)*NLEN+53) - NLESS=MAX(184-NLEN,0) - CPDS(29:40-NLESS)=CBUF((K-1)*NLEN+173:(K-1)*NLEN+184-NLESS) - KPTR=0 - CALL GBYTEC(CBUF,KPTR(3),(K-1)*NLEN*8+25*8,3*8) - KPDS(18)=1 - CALL GBYTEC(CPDS,KPDS(4),7*8,8) - CALL FI632(CPDS,KPTR,KPDS,KRET) - ENDIF - IF(LGDSP.EQ.0) THEN - CGDS=CHAR(0) - CGDS(1:42)=CBUF((K-1)*NLEN+54:(K-1)*NLEN+95) - NLESS=MAX(320-NLEN,0) - CGDS(43:178-NLESS)=CBUF((K-1)*NLEN+185:(K-1)*NLEN+320-NLESS) - KPTR=0 - CALL FI633(CGDS,KPTR,KGDS,KRET) - ENDIF - IF(KPDS(23).EQ.2.AND.LENSP.EQ.0) THEN - NLESS=MAX(172-NLEN,0) - CPDS(41:100-NLESS)=CBUF((K-1)*NLEN+113:(K-1)*NLEN+172-NLESS) - CALL PDSEUP(KENS,KPROB,XPROB,KCLUST,KMEMBR,45,CPDS) - ENDIF - IRET=0 - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbe.f b/external/w3nco/v2.0.6/src/getgbe.f deleted file mode 100644 index 156952254..000000000 --- a/external/w3nco/v2.0.6/src/getgbe.f +++ /dev/null @@ -1,223 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBE(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, - & KF,K,KPDS,KGDS,KENS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBE FINDS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND AND UNPACK A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C (THE INDEX BUFFER IS SAVED FOR USE BY FUTURE PROSPECTIVE CALLS.) -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE AND UNPACKED. ITS MESSAGE NUMBER IS RETURNED ALONG WITH -C THE UNPACKED PDS AND GDS PARAMETERS, THE UNPACKED BITMAP (IF ANY), -C AND THE UNPACKED DATA. IF THE GRIB MESSAGE IS NOT FOUND, THEN THE -C RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBE(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, -C & KF,K,KPDS,KGDS,KENS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JF INTEGER MAXIMUM NUMBER OF DATA POINTS TO UNPACK -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C OUTPUT ARGUMENTS: -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF DATA POINTS GREATER THAN JF -C 99 REQUEST NOT FOUND -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C GETGBEM FIND AND UNPACK GRIB MESSAGE -C -C REMARKS: IN ORDER TO UNPACK GRIB FROM A MULTIPROCESSING ENVIRONMENT -C WHERE EACH PROCESSOR IS ATTEMPTING TO READ FROM ITS OWN PAIR OF -C LOGICAL UNITS, ONE MUST DIRECTLY CALL SUBPROGRAM GETGBEM AS BELOW, -C ALLOCATING A PRIVATE COPY OF CBUF, NLEN AND NNUM TO EACH PROCESSOR. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - LOGICAL*1 LB(JF) - REAL F(JF) - PARAMETER(MBUF=256*1024) - CHARACTER CBUF(MBUF) - SAVE CBUF,NLEN,NNUM,MNUM - DATA LUX/0/ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE WHETHER INDEX BUFFER NEEDS TO BE INITIALIZED - IF(LUGI.GT.0.AND.(J.LT.0.OR.LUGI.NE.LUX)) THEN - LUX=LUGI - JJ=MIN(J,-1-J) - ELSEIF(LUGI.LE.0.AND.(J.LT.0.OR.LUGB.NE.LUX)) THEN - LUX=LUGB - JJ=MIN(J,-1-J) - ELSE - JJ=J - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FIND AND UNPACK GRIB MESSAGE - CALL GETGBEM(LUGB,LUGI,JF,JJ,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KF,K,KPDS,KGDS,KENS,LB,F,IRET) - IF(IRET.EQ.96) LUX=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbeh.f b/external/w3nco/v2.0.6/src/getgbeh.f deleted file mode 100644 index 030bed06f..000000000 --- a/external/w3nco/v2.0.6/src/getgbeh.f +++ /dev/null @@ -1,215 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBEH(LUGB,LUGI,J,JPDS,JGDS,JENS, - & KG,KF,K,KPDS,KGDS,KENS,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBEH FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C (THE INDEX BUFFER IS SAVED FOR USE BY FUTURE PROSPECTIVE CALLS.) -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN ITS MESSAGE NUMBER IS -C RETURNED ALONG WITH THE UNPACKED PDS AND GDS PARAMETERS. IF THE -C GRIB MESSAGE IS NOT FOUND, THEN THE RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBEH(LUGB,LUGI,J,JPDS,JGDS,JENS, -C & KG,KF,K,KPDS,KGDS,KENS,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C (ONLY USED IF LUGI=0) -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C OUTPUT ARGUMENTS: -C KG INTEGER NUMBER OF BYTES IN THE GRIB MESSAGE -C KF INTEGER NUMBER OF DATA POINTS IN THE MESSAGE -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 99 REQUEST NOT FOUND -C -C SUBPROGRAMS CALLED: -C GETGBEMH FIND GRIB MESSAGE -C -C REMARKS: IN ORDER TO UNPACK GRIB FROM A MULTIPROCESSING ENVIRONMENT -C WHERE EACH PROCESSOR IS ATTEMPTING TO READ FROM ITS OWN PAIR OF -C LOGICAL UNITS, ONE MUST DIRECTLY CALL SUBPROGRAM GETGBEMH AS BELOW, -C ALLOCATING A PRIVATE COPY OF CBUF, NLEN AND NNUM TO EACH PROCESSOR. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - PARAMETER(MBUF=256*1024) - CHARACTER CBUF(MBUF) - SAVE CBUF,NLEN,NNUM,MNUM - DATA LUX/0/ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE WHETHER INDEX BUFFER NEEDS TO BE INITIALIZED - IF(LUGI.GT.0.AND.(J.LT.0.OR.LUGI.NE.LUX)) THEN - LUX=LUGI - JJ=MIN(J,-1-J) - ELSEIF(LUGI.LE.0.AND.(J.LT.0.OR.LUGB.NE.LUX)) THEN - LUX=LUGB - JJ=MIN(J,-1-J) - ELSE - JJ=J - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FIND AND UNPACK GRIB MESSAGE - CALL GETGBEMH(LUGB,LUGI,JJ,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KG,KF,K,KPDS,KGDS,KENS,IRET) - IF(IRET.EQ.96) LUX=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbem.f b/external/w3nco/v2.0.6/src/getgbem.f deleted file mode 100644 index 87655b840..000000000 --- a/external/w3nco/v2.0.6/src/getgbem.f +++ /dev/null @@ -1,275 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBEM(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KF,K,KPDS,KGDS,KENS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBEM FINDS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND AND UNPACK A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE AND UNPACKED. ITS MESSAGE NUMBER IS RETURNED ALONG WITH -C THE UNPACKED PDS AND GDS PARAMETERS, THE UNPACKED BITMAP (IF ANY), -C AND THE UNPACKED DATA. IF THE GRIB MESSAGE IS NOT FOUND, THEN THE -C RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBEM(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, -C & MBUF,CBUF,NLEN,NNUM,MNUM, -C & KF,K,KPDS,KGDS,KENS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JF INTEGER MAXIMUM NUMBER OF DATA POINTS TO UNPACK -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C MBUF INTEGER LENGTH OF INDEX BUFFER IN BYTES -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C (INITIALIZE BY SETTING J=-1) -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C (INITIALIZE BY SETTING J=-1) -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (INITIALIZE BY SETTING J=-1) -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C (INITIALIZE BY SETTING J=-1) -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF DATA POINTS GREATER THAN JF -C 99 REQUEST NOT FOUND -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C GETGI READ INDEX FILE -C GETGIR READ INDEX BUFFER FROM GRIB FILE -C GETGB1S SEARCH INDEX RECORDS -C GETGB1R READ AND UNPACK GRIB RECORD -C LENGDS RETURN THE LENGTH OF A GRID -C -C REMARKS: SPECIFY AN INDEX FILE IF FEASIBLE TO INCREASE SPEED. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - CHARACTER CBUF(MBUF) - LOGICAL*1 LB(JF) - REAL F(JF) - PARAMETER(MSK1=32000,MSK2=4000) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH PREVIOUS INDEX BUFFER IF POSSIBLE - IF(J.GE.0) THEN - IF(MNUM.GE.0) THEN - IRGI=0 - ELSE - MNUM=-1-MNUM - IRGI=1 - ENDIF - JR=J-MNUM - IF(JR.GE.0.AND.(JR.LT.NNUM.OR.IRGI.EQ.0)) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ELSE - MNUM=J - IRGI=1 - IRGS=1 - ENDIF - ELSE - MNUM=-1-J - IRGI=1 - IRGS=1 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND SEARCH NEXT INDEX BUFFER - JR=0 - DOWHILE(IRGI.EQ.1.AND.IRGS.EQ.1) - IF(LUGI.GT.0) THEN - CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ELSE - CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ENDIF - IF(IRGI.LE.1) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND UNPACK GRIB RECORD - IF(IRGI.GT.1) THEN - IRET=96 - ELSEIF(IRGS.NE.0) THEN - IRET=99 - ELSEIF(LENGDS(KGDS).GT.JF) THEN - IRET=98 - ELSE - CALL GETGB1R(LUGB,LSKIP,LGRIB,KF,KPDS,KGDS,KENS,LB,F,NBITS, - & IRET) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbemh.f b/external/w3nco/v2.0.6/src/getgbemh.f deleted file mode 100644 index deb36ab80..000000000 --- a/external/w3nco/v2.0.6/src/getgbemh.f +++ /dev/null @@ -1,265 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBEMH(LUGB,LUGI,J,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KG,KF,K,KPDS,KGDS,KENS,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBEMH FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN ITS MESSAGE NUMBER IS -C RETURNED ALONG WITH THE UNPACKED PDS AND GDS PARAMETERS. IF THE -C GRIB MESSAGE IS NOT FOUND, THEN THE RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBEMH(LUGB,LUGI,J,JPDS,JGDS,JENS, -C & MBUF,CBUF,NLEN,NNUM,MNUM, -C & KG,KF,K,KPDS,KGDS,KENS,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C (ONLY USED IF LUGI=0) -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C MBUF INTEGER LENGTH OF INDEX BUFFER IN BYTES -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C (INITIALIZE BY SETTING J=-1) -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C (INITIALIZE BY SETTING J=-1) -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (INITIALIZE BY SETTING J=-1) -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C (INITIALIZE BY SETTING J=-1) -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C KG INTEGER NUMBER OF BYTES IN THE GRIB MESSAGE -C KF INTEGER NUMBER OF DATA POINTS IN THE MESSAGE -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 99 REQUEST NOT FOUND -C -C SUBPROGRAMS CALLED: -C GETGI READ INDEX FILE -C GETGIR READ INDEX BUFFER FROM GRIB FILE -C GETGB1S SEARCH INDEX RECORDS -C LENGDS RETURN THE LENGTH OF A GRID -C -C REMARKS: SPECIFY AN INDEX FILE IF FEASIBLE TO INCREASE SPEED. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - CHARACTER CBUF(MBUF) - PARAMETER(MSK1=32000,MSK2=4000) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH PREVIOUS INDEX BUFFER IF POSSIBLE - IF(J.GE.0) THEN - IF(MNUM.GE.0) THEN - IRGI=0 - ELSE - MNUM=-1-MNUM - IRGI=1 - ENDIF - JR=J-MNUM - IF(JR.GE.0.AND.(JR.LT.NNUM.OR.IRGI.EQ.0)) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ELSE - MNUM=J - IRGI=1 - IRGS=1 - ENDIF - ELSE - MNUM=-1-J - IRGI=1 - IRGS=1 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND SEARCH NEXT INDEX BUFFER - JR=0 - DOWHILE(IRGI.EQ.1.AND.IRGS.EQ.1) - IF(LUGI.GT.0) THEN - CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ELSE - CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ENDIF - IF(IRGI.LE.1) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ GRIB RECORD - IF(IRGI.GT.1) THEN - IRET=96 - ELSEIF(IRGS.NE.0) THEN - IRET=99 - ELSE - KG=LGRIB - KF=LENGDS(KGDS) - IRET=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbemn.f b/external/w3nco/v2.0.6/src/getgbemn.f deleted file mode 100644 index b3a4d4404..000000000 --- a/external/w3nco/v2.0.6/src/getgbemn.f +++ /dev/null @@ -1,277 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBEMN(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KF,K,KPDS,KGDS,KENS,LB,F,NBITSS,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBEM FINDS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND AND UNPACK A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE AND UNPACKED. ITS MESSAGE NUMBER IS RETURNED ALONG WITH -C THE UNPACKED PDS AND GDS PARAMETERS, THE UNPACKED BITMAP (IF ANY), -C AND THE UNPACKED DATA. IF THE GRIB MESSAGE IS NOT FOUND, THEN THE -C RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C 04-07-22 CHUANG ADD PACKING BIT NUMBER NBITSS IN THE ARGUMENT -C LIST BECAUSE ETA GRIB FILES NEED IT TO REPACK GRIB FILE -C -C USAGE: CALL GETGBEM(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, -C & MBUF,CBUF,NLEN,NNUM,MNUM, -C & KF,K,KPDS,KGDS,KENS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JF INTEGER MAXIMUM NUMBER OF DATA POINTS TO UNPACK -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C MBUF INTEGER LENGTH OF INDEX BUFFER IN BYTES -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C (INITIALIZE BY SETTING J=-1) -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C (INITIALIZE BY SETTING J=-1) -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (INITIALIZE BY SETTING J=-1) -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C (INITIALIZE BY SETTING J=-1) -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF DATA POINTS GREATER THAN JF -C 99 REQUEST NOT FOUND -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C GETGI READ INDEX FILE -C GETGIR READ INDEX BUFFER FROM GRIB FILE -C GETGB1S SEARCH INDEX RECORDS -C GETGB1R READ AND UNPACK GRIB RECORD -C LENGDS RETURN THE LENGTH OF A GRID -C -C REMARKS: SPECIFY AN INDEX FILE IF FEASIBLE TO INCREASE SPEED. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - CHARACTER CBUF(MBUF) - LOGICAL*1 LB(JF) - REAL F(JF) - PARAMETER(MSK1=32000,MSK2=4000) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH PREVIOUS INDEX BUFFER IF POSSIBLE - IF(J.GE.0) THEN - IF(MNUM.GE.0) THEN - IRGI=0 - ELSE - MNUM=-1-MNUM - IRGI=1 - ENDIF - JR=J-MNUM - IF(JR.GE.0.AND.(JR.LT.NNUM.OR.IRGI.EQ.0)) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ELSE - MNUM=J - IRGI=1 - IRGS=1 - ENDIF - ELSE - MNUM=-1-J - IRGI=1 - IRGS=1 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND SEARCH NEXT INDEX BUFFER - JR=0 - DOWHILE(IRGI.EQ.1.AND.IRGS.EQ.1) - IF(LUGI.GT.0) THEN - CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ELSE - CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ENDIF - IF(IRGI.LE.1) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND UNPACK GRIB RECORD - IF(IRGI.GT.1) THEN - IRET=96 - ELSEIF(IRGS.NE.0) THEN - IRET=99 - ELSEIF(LENGDS(KGDS).GT.JF) THEN - IRET=98 - ELSE - CALL GETGB1R(LUGB,LSKIP,LGRIB,KF,KPDS,KGDS,KENS,LB,F,NBITSS - & ,IRET) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbemp.f b/external/w3nco/v2.0.6/src/getgbemp.f deleted file mode 100644 index b21b83ce3..000000000 --- a/external/w3nco/v2.0.6/src/getgbemp.f +++ /dev/null @@ -1,271 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBEMP(LUGB,LUGI,JG,J,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KG,K,KPDS,KGDS,KENS,G,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBEMP FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE. ITS MESSAGE NUMBER IS RETURNED ALONG WITH THE UNPACKED -C PDS AND GDS PARAMETERS AND THE PACKED GRIB MESSAGE. IF THE GRIB -C MESSAGE IS NOT FOUND, THEN THE RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBEMP(LUGB,LUGI,JG,J,JPDS,JGDS,JENS, -C & MBUF,CBUF,NLEN,NNUM,MNUM, -C & KG,K,KPDS,KGDS,KENS,G,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JG INTEGER MAXIMUM NUMBER OF BYTES IN THE GRIB MESSAGE -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C MBUF INTEGER LENGTH OF INDEX BUFFER IN BYTES -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C (INITIALIZE BY SETTING J=-1) -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C (INITIALIZE BY SETTING J=-1) -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (INITIALIZE BY SETTING J=-1) -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C (INITIALIZE BY SETTING J=-1) -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C KG INTEGER NUMBER OF BYTES IN THE GRIB MESSAGE -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C G CHARACTER*1 (KG) GRIB MESSAGE -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF BYTES GREATER THAN JG -C 99 REQUEST NOT FOUND -C -C SUBPROGRAMS CALLED: -C GETGI READ INDEX FILE -C GETGIR READ INDEX BUFFER FROM GRIB FILE -C GETGB1S SEARCH INDEX RECORDS -C BAREAD READ GRIB RECORD -C -C REMARKS: SPECIFY AN INDEX FILE IF FEASIBLE TO INCREASE SPEED. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - CHARACTER CBUF(MBUF) - CHARACTER G(JG) - PARAMETER(MSK1=32000,MSK2=4000) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH PREVIOUS INDEX BUFFER IF POSSIBLE - IF(J.GE.0) THEN - IF(MNUM.GE.0) THEN - IRGI=0 - ELSE - MNUM=-1-MNUM - IRGI=1 - ENDIF - JR=J-MNUM - IF(JR.GE.0.AND.(JR.LT.NNUM.OR.IRGI.EQ.0)) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ELSE - MNUM=J - IRGI=1 - IRGS=1 - ENDIF - ELSE - MNUM=-1-J - IRGI=1 - IRGS=1 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND SEARCH NEXT INDEX BUFFER - JR=0 - DOWHILE(IRGI.EQ.1.AND.IRGS.EQ.1) - IF(LUGI.GT.0) THEN - CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ELSE - CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ENDIF - IF(IRGI.LE.1) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ GRIB RECORD - IF(IRGI.GT.1) THEN - IRET=96 - ELSEIF(IRGS.NE.0) THEN - IRET=99 - ELSEIF(LGRIB.GT.JG) THEN - IRET=98 - ELSE - IRET=97 - CALL BAREAD(LUGB,LSKIP,LGRIB,KG,G) - IF(KG.EQ.LGRIB) IRET=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbep.f b/external/w3nco/v2.0.6/src/getgbep.f deleted file mode 100644 index 19faea071..000000000 --- a/external/w3nco/v2.0.6/src/getgbep.f +++ /dev/null @@ -1,219 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBEP(LUGB,LUGI,JG,J,JPDS,JGDS,JENS, - & KG,K,KPDS,KGDS,KENS,G,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBEP FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C (THE INDEX BUFFER IS SAVED FOR USE BY FUTURE PROSPECTIVE CALLS.) -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE. ITS MESSAGE NUMBER IS RETURNED ALONG WITH THE UNPACKED -C PDS AND GDS PARAMETERS AND THE PACKED GRIB MESSAGE. IF THE GRIB -C MESSAGE IS NOT FOUND, THEN THE RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBEP(LUGB,LUGI,JG,J,JPDS,JGDS,JENS, -C & KG,K,KPDS,KGDS,KENS,G,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JG INTEGER MAXIMUM NUMBER OF BYTES IN THE GRIB MESSAGE -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C OUTPUT ARGUMENTS: -C KG INTEGER NUMBER OF BYTES IN THE GRIB MESSAGE -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C G CHARACTER*1 (KG) GRIB MESSAGE -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF BYTES GREATER THAN JG -C 99 REQUEST NOT FOUND -C -C SUBPROGRAMS CALLED: -C GETGBEMP FIND GRIB MESSAGE -C -C REMARKS: IN ORDER TO UNPACK GRIB FROM A MULTIPROCESSING ENVIRONMENT -C WHERE EACH PROCESSOR IS ATTEMPTING TO READ FROM ITS OWN PAIR OF -C LOGICAL UNITS, ONE MUST DIRECTLY CALL SUBPROGRAM GETGBEMP AS BELOW, -C ALLOCATING A PRIVATE COPY OF CBUF, NLEN AND NNUM TO EACH PROCESSOR. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - CHARACTER G(JG) - PARAMETER(MBUF=256*1024) - CHARACTER CBUF(MBUF) - SAVE CBUF,NLEN,NNUM,MNUM - DATA LUX/0/ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE WHETHER INDEX BUFFER NEEDS TO BE INITIALIZED - IF(LUGI.GT.0.AND.(J.LT.0.OR.LUGI.NE.LUX)) THEN - LUX=LUGI - JJ=MIN(J,-1-J) - ELSEIF(LUGI.LE.0.AND.(J.LT.0.OR.LUGB.NE.LUX)) THEN - LUX=LUGB - JJ=MIN(J,-1-J) - ELSE - JJ=J - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FIND AND UNPACK GRIB MESSAGE - CALL GETGBEMP(LUGB,LUGI,JG,JJ,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KG,K,KPDS,KGDS,KENS,G,IRET) - IF(IRET.EQ.96) LUX=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbex.f b/external/w3nco/v2.0.6/src/getgbex.f deleted file mode 100644 index 4698b0fa4..000000000 --- a/external/w3nco/v2.0.6/src/getgbex.f +++ /dev/null @@ -1,233 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBEX(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, - & KF,K,KPDS,KGDS,KENS,KPROB,XPROB,KCLUST,KMEMBR, - & LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBEX FINDS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND AND UNPACK A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C (THE INDEX BUFFER IS SAVED FOR USE BY FUTURE PROSPECTIVE CALLS.) -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE AND UNPACKED. ITS MESSAGE NUMBER IS RETURNED ALONG WITH -C THE UNPACKED PDS AND GDS PARAMETERS, THE UNPACKED BITMAP (IF ANY), -C AND THE UNPACKED DATA. IF THE GRIB MESSAGE IS NOT FOUND, THEN THE -C RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C 97-02-11 Y.ZHU INCLUDED PROBABILITY AND CLUSTER ARGUMENTS -C -C USAGE: CALL GETGBEX(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, -C & KF,K,KPDS,KGDS,KENS,KPROB,XPROB,KCLUST,KMEMBR, -C & LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JF INTEGER MAXIMUM NUMBER OF DATA POINTS TO UNPACK -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C OUTPUT ARGUMENTS: -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C KPROB INTEGER (2) PROBABILITY ENSEMBLE PARMS -C XPROB REAL (2) PROBABILITY ENSEMBLE PARMS -C KCLUST INTEGER (16) CLUSTER ENSEMBLE PARMS -C KMEMBR INTEGER (8) CLUSTER ENSEMBLE PARMS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF DATA POINTS GREATER THAN JF -C 99 REQUEST NOT FOUND -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C GETGBEXM FIND AND UNPACK GRIB MESSAGE -C -C REMARKS: IN ORDER TO UNPACK GRIB FROM A MULTIPROCESSING ENVIRONMENT -C WHERE EACH PROCESSOR IS ATTEMPTING TO READ FROM ITS OWN PAIR OF -C LOGICAL UNITS, ONE MUST DIRECTLY CALL SUBPROGRAM GETGBEXM AS BELOW, -C ALLOCATING A PRIVATE COPY OF CBUF, NLEN AND NNUM TO EACH PROCESSOR. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - INTEGER KPROB(2),KCLUST(16),KMEMBR(80) - REAL XPROB(2) - LOGICAL*1 LB(JF) - REAL F(JF) - PARAMETER(MBUF=256*1024) - CHARACTER CBUF(MBUF) - SAVE CBUF,NLEN,NNUM,MNUM - DATA LUX/0/ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE WHETHER INDEX BUFFER NEEDS TO BE INITIALIZED - IF(LUGI.GT.0.AND.(J.LT.0.OR.LUGI.NE.LUX)) THEN - LUX=LUGI - JJ=MIN(J,-1-J) - ELSEIF(LUGI.LE.0.AND.(J.LT.0.OR.LUGB.NE.LUX)) THEN - LUX=LUGB - JJ=MIN(J,-1-J) - ELSE - JJ=J - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FIND AND UNPACK GRIB MESSAGE - CALL GETGBEXM(LUGB,LUGI,JF,JJ,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KF,K,KPDS,KGDS,KENS,KPROB,XPROB,KCLUST,KMEMBR, - & LB,F,IRET) - IF(IRET.EQ.96) LUX=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbexm.f b/external/w3nco/v2.0.6/src/getgbexm.f deleted file mode 100644 index 765c6d5a0..000000000 --- a/external/w3nco/v2.0.6/src/getgbexm.f +++ /dev/null @@ -1,284 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBEXM(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KF,K,KPDS,KGDS,KENS,KPROB,XPROB,KCLUST,KMEMBR, - & LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBEXM FINDS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND AND UNPACK A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE AND UNPACKED. ITS MESSAGE NUMBER IS RETURNED ALONG WITH -C THE UNPACKED PDS AND GDS PARAMETERS, THE UNPACKED BITMAP (IF ANY), -C AND THE UNPACKED DATA. IF THE GRIB MESSAGE IS NOT FOUND, THEN THE -C RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C 97-02-11 Y.ZHU INCLUDED PROBABILITY AND CLUSTER ARGUMENTS -C -C USAGE: CALL GETGBEXM(LUGB,LUGI,JF,J,JPDS,JGDS,JENS, -C & MBUF,CBUF,NLEN,NNUM,MNUM, -C & KF,K,KPDS,KGDS,KENS,KPROB,XPROB,KCLUST,KMEMBR, -C & LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JF INTEGER MAXIMUM NUMBER OF DATA POINTS TO UNPACK -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C JENS INTEGER (200) ENSEMBLE PDS PARMS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(23)=2) -C (=-1 FOR WILDCARD) -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C MBUF INTEGER LENGTH OF INDEX BUFFER IN BYTES -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C (INITIALIZE BY SETTING J=-1) -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C (INITIALIZE BY SETTING J=-1) -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (INITIALIZE BY SETTING J=-1) -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C (INITIALIZE BY SETTING J=-1) -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C KENS INTEGER (200) UNPACKED ENSEMBLE PDS PARMS -C KPROB INTEGER (2) PROBABILITY ENSEMBLE PARMS -C XPROB REAL (2) PROBABILITY ENSEMBLE PARMS -C KCLUST INTEGER (16) CLUSTER ENSEMBLE PARMS -C KMEMBR INTEGER (8) CLUSTER ENSEMBLE PARMS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF DATA POINTS GREATER THAN JF -C 99 REQUEST NOT FOUND -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C GETGI READ INDEX FILE -C GETGIR READ INDEX BUFFER FROM GRIB FILE -C GETGB1S SEARCH INDEX RECORDS -C GETGB1RE READ AND UNPACK GRIB RECORD -C LENGDS RETURN THE LENGTH OF A GRID -C -C REMARKS: SPECIFY AN INDEX FILE IF FEASIBLE TO INCREASE SPEED. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),JENS(200) - INTEGER KPDS(200),KGDS(200),KENS(200) - INTEGER KPROB(2),KCLUST(16),KMEMBR(80) - REAL XPROB(2) - CHARACTER CBUF(MBUF) - LOGICAL*1 LB(JF) - REAL F(JF) - PARAMETER(MSK1=32000,MSK2=4000) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH PREVIOUS INDEX BUFFER IF POSSIBLE - IF(J.GE.0) THEN - IF(MNUM.GE.0) THEN - IRGI=0 - ELSE - MNUM=-1-MNUM - IRGI=1 - ENDIF - JR=J-MNUM - IF(JR.GE.0.AND.(JR.LT.NNUM.OR.IRGI.EQ.0)) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ELSE - MNUM=J - IRGI=1 - IRGS=1 - ENDIF - ELSE - MNUM=-1-J - IRGI=1 - IRGS=1 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND SEARCH NEXT INDEX BUFFER - JR=0 - DOWHILE(IRGI.EQ.1.AND.IRGS.EQ.1) - IF(LUGI.GT.0) THEN - CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ELSE - CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ENDIF - IF(IRGI.LE.1) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND UNPACK GRIB RECORD - IF(IRGI.GT.1) THEN - IRET=96 - ELSEIF(IRGS.NE.0) THEN - IRET=99 - ELSEIF(LENGDS(KGDS).GT.JF) THEN - IRET=98 - ELSE - CALL GETGB1RE(LUGB,LSKIP,LGRIB,KF,KPDS,KGDS,KENS, - & KPROB,XPROB,KCLUST,KMEMBR,LB,F,IRET) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbh.f b/external/w3nco/v2.0.6/src/getgbh.f deleted file mode 100644 index 115dee4ac..000000000 --- a/external/w3nco/v2.0.6/src/getgbh.f +++ /dev/null @@ -1,206 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBH(LUGB,LUGI,J,JPDS,JGDS, - & KG,KF,K,KPDS,KGDS,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBH FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C (THE INDEX BUFFER IS SAVED FOR USE BY FUTURE PROSPECTIVE CALLS.) -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN ITS MESSAGE NUMBER IS -C RETURNED ALONG WITH THE UNPACKED PDS AND GDS PARAMETERS. IF THE -C GRIB MESSAGE IS NOT FOUND, THEN THE RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBH(LUGB,LUGI,J,JPDS,JGDS, -C & KG,KF,K,KPDS,KGDS,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C (ONLY USED IF LUGI=0) -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C OUTPUT ARGUMENTS: -C KG INTEGER NUMBER OF BYTES IN THE GRIB MESSAGE -C KF INTEGER NUMBER OF DATA POINTS IN THE MESSAGE -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 99 REQUEST NOT FOUND -C -C SUBPROGRAMS CALLED: -C GETGBMH FIND GRIB MESSAGE -C -C REMARKS: IN ORDER TO UNPACK GRIB FROM A MULTIPROCESSING ENVIRONMENT -C WHERE EACH PROCESSOR IS ATTEMPTING TO READ FROM ITS OWN PAIR OF -C LOGICAL UNITS, ONE MUST DIRECTLY CALL SUBPROGRAM GETGBMH AS BELOW, -C ALLOCATING A PRIVATE COPY OF CBUF, NLEN AND NNUM TO EACH PROCESSOR. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200) - INTEGER KPDS(200),KGDS(200) - PARAMETER(MBUF=256*1024) - CHARACTER CBUF(MBUF) - SAVE CBUF,NLEN,NNUM,MNUM - DATA LUX/0/ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE WHETHER INDEX BUFFER NEEDS TO BE INITIALIZED - IF(LUGI.GT.0.AND.(J.LT.0.OR.LUGI.NE.LUX)) THEN - LUX=LUGI - JJ=MIN(J,-1-J) - ELSEIF(LUGI.LE.0.AND.(J.LT.0.OR.LUGB.NE.LUX)) THEN - LUX=LUGB - JJ=MIN(J,-1-J) - ELSE - JJ=J - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FIND AND UNPACK GRIB MESSAGE - CALL GETGBMH(LUGB,LUGI,JJ,JPDS,JGDS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KG,KF,K,KPDS,KGDS,IRET) - IF(IRET.EQ.96) LUX=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbm.f b/external/w3nco/v2.0.6/src/getgbm.f deleted file mode 100644 index 4c4e57f58..000000000 --- a/external/w3nco/v2.0.6/src/getgbm.f +++ /dev/null @@ -1,271 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBM(LUGB,LUGI,JF,J,JPDS,JGDS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KF,K,KPDS,KGDS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBM FINDS AND UNPACKS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND AND UNPACK A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE AND UNPACKED. ITS MESSAGE NUMBER IS RETURNED ALONG WITH -C THE UNPACKED PDS AND GDS PARAMETERS, THE UNPACKED BITMAP (IF ANY), -C AND THE UNPACKED DATA. IF THE GRIB MESSAGE IS NOT FOUND, THEN THE -C RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C 04-07-22 CHUANG ADD NBITSS TO THE ARGUMENT LIST OF GETGB1R THAT -C IS CALLED IN THIS SUBROUTINE -C 10-03-02 WANG INCREASE MSK1 TO 256000000 FOR NEMSIO FILES -C -C USAGE: CALL GETGBM(LUGB,LUGI,JF,J,JPDS,JGDS, -C & MBUF,CBUF,NLEN,NNUM,MNUM, -C & KF,K,KPDS,KGDS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JF INTEGER MAXIMUM NUMBER OF DATA POINTS TO UNPACK -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C MBUF INTEGER LENGTH OF INDEX BUFFER IN BYTES -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C (INITIALIZE BY SETTING J=-1) -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C (INITIALIZE BY SETTING J=-1) -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (INITIALIZE BY SETTING J=-1) -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C (INITIALIZE BY SETTING J=-1) -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C KF INTEGER NUMBER OF DATA POINTS UNPACKED -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C LB LOGICAL*1 (KF) UNPACKED BITMAP IF PRESENT -C F REAL (KF) UNPACKED DATA -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF DATA POINTS GREATER THAN JF -C 99 REQUEST NOT FOUND -C OTHER W3FI63 GRIB UNPACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C GETGI READ INDEX FILE -C GETGIR READ INDEX BUFFER FROM GRIB FILE -C GETGB1S SEARCH INDEX RECORDS -C GETGB1R READ AND UNPACK GRIB RECORD -C LENGDS RETURN THE LENGTH OF A GRID -C -C REMARKS: SPECIFY AN INDEX FILE IF FEASIBLE TO INCREASE SPEED. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200) - INTEGER KPDS(200),KGDS(200) - CHARACTER CBUF(MBUF) - LOGICAL*1 LB(JF) - REAL F(JF) - PARAMETER(MSK1=256000000,MSK2=4000) - INTEGER JENS(200),KENS(200) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH PREVIOUS INDEX BUFFER IF POSSIBLE - JENS=-1 - IF(J.GE.0) THEN - IF(MNUM.GE.0) THEN - IRGI=0 - ELSE - MNUM=-1-MNUM - IRGI=1 - ENDIF - JR=J-MNUM - IF(JR.GE.0.AND.(JR.LT.NNUM.OR.IRGI.EQ.0)) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ELSE - MNUM=J - IRGI=1 - IRGS=1 - ENDIF - ELSE - MNUM=-1-J - IRGI=1 - IRGS=1 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND SEARCH NEXT INDEX BUFFER - JR=0 - DO WHILE(IRGI.EQ.1.AND.IRGS.EQ.1) - IF(LUGI.GT.0) THEN - CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ELSE - CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ENDIF - IF(IRGI.LE.1) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND UNPACK GRIB RECORD - IF(IRGI.GT.1) THEN - IRET=96 - ELSEIF(IRGS.NE.0) THEN - IRET=99 - ELSEIF(LENGDS(KGDS).GT.JF) THEN - IRET=98 - ELSE - CALL GETGB1R(LUGB,LSKIP,LGRIB,KF,KPDS,KGDS,KENS,LB,F,NBITSS - & ,IRET) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbmh.f b/external/w3nco/v2.0.6/src/getgbmh.f deleted file mode 100644 index 6d7f78e86..000000000 --- a/external/w3nco/v2.0.6/src/getgbmh.f +++ /dev/null @@ -1,258 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBMH(LUGB,LUGI,J,JPDS,JGDS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KG,KF,K,KPDS,KGDS,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBMH FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN ITS MESSAGE NUMBER IS -C RETURNED ALONG WITH THE UNPACKED PDS AND GDS PARAMETERS. IF THE -C GRIB MESSAGE IS NOT FOUND, THEN THE RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBMH(LUGB,LUGI,J,JPDS,JGDS, -C & MBUF,CBUF,NLEN,NNUM,MNUM, -C & KG,KF,K,KPDS,KGDS,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C (ONLY USED IF LUGI=0) -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C MBUF INTEGER LENGTH OF INDEX BUFFER IN BYTES -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C (INITIALIZE BY SETTING J=-1) -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C (INITIALIZE BY SETTING J=-1) -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (INITIALIZE BY SETTING J=-1) -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C (INITIALIZE BY SETTING J=-1) -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C KG INTEGER NUMBER OF BYTES IN THE GRIB MESSAGE -C KF INTEGER NUMBER OF DATA POINTS IN THE MESSAGE -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 99 REQUEST NOT FOUND -C -C SUBPROGRAMS CALLED: -C GETGI READ INDEX FILE -C GETGIR READ INDEX BUFFER FROM GRIB FILE -C GETGB1S SEARCH INDEX RECORDS -C LENGDS RETURN THE LENGTH OF A GRID -C -C REMARKS: SPECIFY AN INDEX FILE IF FEASIBLE TO INCREASE SPEED. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200) - INTEGER KPDS(200),KGDS(200) - CHARACTER CBUF(MBUF) - PARAMETER(MSK1=32000,MSK2=4000) - INTEGER JENS(200),KENS(200) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH PREVIOUS INDEX BUFFER IF POSSIBLE - JENS=-1 - IF(J.GE.0) THEN - IF(MNUM.GE.0) THEN - IRGI=0 - ELSE - MNUM=-1-MNUM - IRGI=1 - ENDIF - JR=J-MNUM - IF(JR.GE.0.AND.(JR.LT.NNUM.OR.IRGI.EQ.0)) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ELSE - MNUM=J - IRGI=1 - IRGS=1 - ENDIF - ELSE - MNUM=-1-J - IRGI=1 - IRGS=1 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND SEARCH NEXT INDEX BUFFER - JR=0 - DOWHILE(IRGI.EQ.1.AND.IRGS.EQ.1) - IF(LUGI.GT.0) THEN - CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ELSE - CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ENDIF - IF(IRGI.LE.1) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ GRIB RECORD - IF(IRGI.GT.1) THEN - IRET=96 - ELSEIF(IRGS.NE.0) THEN - IRET=99 - ELSE - KG=LGRIB - KF=LENGDS(KGDS) - IRET=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbmp.f b/external/w3nco/v2.0.6/src/getgbmp.f deleted file mode 100644 index ca6e1ef1e..000000000 --- a/external/w3nco/v2.0.6/src/getgbmp.f +++ /dev/null @@ -1,264 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBMP(LUGB,LUGI,JG,J,JPDS,JGDS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KG,K,KPDS,KGDS,G,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBMP FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE. ITS MESSAGE NUMBER IS RETURNED ALONG WITH THE UNPACKED -C PDS AND GDS PARAMETERS AND THE PACKED GRIB MESSAGE. IF THE GRIB -C MESSAGE IS NOT FOUND, THEN THE RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBMP(LUGB,LUGI,JG,J,JPDS,JGDS, -C & MBUF,CBUF,NLEN,NNUM,MNUM, -C & KG,K,KPDS,KGDS,G,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JG INTEGER MAXIMUM NUMBER OF BYTES IN THE GRIB MESSAGE -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C MBUF INTEGER LENGTH OF INDEX BUFFER IN BYTES -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C (INITIALIZE BY SETTING J=-1) -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C (INITIALIZE BY SETTING J=-1) -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (INITIALIZE BY SETTING J=-1) -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C (INITIALIZE BY SETTING J=-1) -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) INDEX BUFFER -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C MNUM INTEGER NUMBER OF INDEX RECORDS SKIPPED -C KG INTEGER NUMBER OF BYTES IN THE GRIB MESSAGE -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C G CHARACTER*1 (KG) GRIB MESSAGE -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF BYTES GREATER THAN JG -C 99 REQUEST NOT FOUND -C -C SUBPROGRAMS CALLED: -C GETGI READ INDEX FILE -C GETGIR READ INDEX BUFFER FROM GRIB FILE -C GETGB1S SEARCH INDEX RECORDS -C BAREAD READ GRIB RECORD -C -C REMARKS: SPECIFY AN INDEX FILE IF FEASIBLE TO INCREASE SPEED. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200) - INTEGER KPDS(200),KGDS(200) - CHARACTER CBUF(MBUF) - CHARACTER G(JG) - PARAMETER(MSK1=32000,MSK2=4000) - INTEGER JENS(200),KENS(200) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH PREVIOUS INDEX BUFFER IF POSSIBLE - JENS=-1 - IF(J.GE.0) THEN - IF(MNUM.GE.0) THEN - IRGI=0 - ELSE - MNUM=-1-MNUM - IRGI=1 - ENDIF - JR=J-MNUM - IF(JR.GE.0.AND.(JR.LT.NNUM.OR.IRGI.EQ.0)) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ELSE - MNUM=J - IRGI=1 - IRGS=1 - ENDIF - ELSE - MNUM=-1-J - IRGI=1 - IRGS=1 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ AND SEARCH NEXT INDEX BUFFER - JR=0 - DOWHILE(IRGI.EQ.1.AND.IRGS.EQ.1) - IF(LUGI.GT.0) THEN - CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ELSE - CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRGI) - ENDIF - IF(IRGI.LE.1) THEN - CALL GETGB1S(CBUF,NLEN,NNUM,JR,JPDS,JGDS,JENS, - & KR,KPDS,KGDS,KENS,LSKIP,LGRIB,IRGS) - IF(IRGS.EQ.0) K=KR+MNUM - IF(IRGI.EQ.1.AND.IRGS.EQ.0) MNUM=-1-MNUM - IF(IRGI.EQ.1.AND.IRGS.GT.0) MNUM=MNUM+NNUM - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C READ GRIB RECORD - IF(IRGI.GT.1) THEN - IRET=96 - ELSEIF(IRGS.NE.0) THEN - IRET=99 - ELSEIF(LGRIB.GT.JG) THEN - IRET=98 - ELSE - IRET=97 - CALL BAREAD(LUGB,LSKIP,LGRIB,KG,G) - IF(KG.EQ.LGRIB) IRET=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgbp.f b/external/w3nco/v2.0.6/src/getgbp.f deleted file mode 100644 index fdfd486e1..000000000 --- a/external/w3nco/v2.0.6/src/getgbp.f +++ /dev/null @@ -1,209 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGBP(LUGB,LUGI,JG,J,JPDS,JGDS, - & KG,K,KPDS,KGDS,G,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGBP FINDS A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: FIND A GRIB MESSAGE. -C READ A GRIB INDEX FILE (OR OPTIONALLY THE GRIB FILE ITSELF) -C TO GET THE INDEX BUFFER (I.E. TABLE OF CONTENTS) FOR THE GRIB FILE. -C (THE INDEX BUFFER IS SAVED FOR USE BY FUTURE PROSPECTIVE CALLS.) -C FIND IN THE INDEX BUFFER A REFERENCE TO THE GRIB MESSAGE REQUESTED. -C THE GRIB MESSAGE REQUEST SPECIFIES THE NUMBER OF MESSAGES TO SKIP -C AND THE UNPACKED PDS AND GDS PARAMETERS. (A REQUESTED PARAMETER -C OF -1 MEANS TO ALLOW ANY VALUE OF THIS PARAMETER TO BE FOUND.) -C IF THE REQUESTED GRIB MESSAGE IS FOUND, THEN IT IS READ FROM THE -C GRIB FILE. ITS MESSAGE NUMBER IS RETURNED ALONG WITH THE UNPACKED -C PDS AND GDS PARAMETERS AND THE PACKED GRIB MESSAGE. IF THE GRIB -C MESSAGE IS NOT FOUND, THEN THE RETURN CODE WILL BE NONZERO. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL MODULARIZED PORTIONS OF CODE INTO SUBPROGRAMS -C AND ALLOWED FOR UNSPECIFIED INDEX FILE -C -C USAGE: CALL GETGBP(LUGB,LUGI,JG,J,JPDS,JGDS, -C & KG,K,KPDS,KGDS,G,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C (=0 TO GET INDEX BUFFER FROM THE GRIB FILE) -C JG INTEGER MAXIMUM NUMBER OF BYTES IN THE GRIB MESSAGE -C J INTEGER NUMBER OF MESSAGES TO SKIP -C (=0 TO SEARCH FROM BEGINNING) -C (<0 TO READ INDEX BUFFER AND SKIP -1-J MESSAGES) -C JPDS INTEGER (200) PDS PARAMETERS FOR WHICH TO SEARCH -C (=-1 FOR WILDCARD) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C JGDS INTEGER (200) GDS PARAMETERS FOR WHICH TO SEARCH -C (ONLY SEARCHED IF JPDS(3)=255) -C (=-1 FOR WILDCARD) -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C OUTPUT ARGUMENTS: -C KG INTEGER NUMBER OF BYTES IN THE GRIB MESSAGE -C K INTEGER MESSAGE NUMBER UNPACKED -C (CAN BE SAME AS J IN CALLING PROGRAM -C IN ORDER TO FACILITATE MULTIPLE SEARCHES) -C KPDS INTEGER (200) UNPACKED PDS PARAMETERS -C KGDS INTEGER (200) UNPACKED GDS PARAMETERS -C G CHARACTER*1 (KG) GRIB MESSAGE -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 96 ERROR READING INDEX FILE -C 97 ERROR READING GRIB FILE -C 98 NUMBER OF BYTES GREATER THAN JG -C 99 REQUEST NOT FOUND -C -C SUBPROGRAMS CALLED: -C GETGBMP FIND GRIB MESSAGE -C -C REMARKS: IN ORDER TO UNPACK GRIB FROM A MULTIPROCESSING ENVIRONMENT -C WHERE EACH PROCESSOR IS ATTEMPTING TO READ FROM ITS OWN PAIR OF -C LOGICAL UNITS, ONE MUST DIRECTLY CALL SUBPROGRAM GETGBMP AS BELOW, -C ALLOCATING A PRIVATE COPY OF CBUF, NLEN AND NNUM TO EACH PROCESSOR. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER JPDS(200),JGDS(200),KPDS(200),KGDS(200) - CHARACTER G(JG) - PARAMETER(MBUF=256*1024) - CHARACTER CBUF(MBUF) - SAVE CBUF,NLEN,NNUM,MNUM - DATA LUX/0/ -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE WHETHER INDEX BUFFER NEEDS TO BE INITIALIZED - IF(LUGI.GT.0.AND.(J.LT.0.OR.LUGI.NE.LUX)) THEN - LUX=LUGI - JJ=MIN(J,-1-J) - ELSEIF(LUGI.LE.0.AND.(J.LT.0.OR.LUGB.NE.LUX)) THEN - LUX=LUGB - JJ=MIN(J,-1-J) - ELSE - JJ=J - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C FIND AND UNPACK GRIB MESSAGE - CALL GETGBMP(LUGB,LUGI,JG,JJ,JPDS,JGDS, - & MBUF,CBUF,NLEN,NNUM,MNUM, - & KG,K,KPDS,KGDS,G,IRET) - IF(IRET.EQ.96) LUX=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgi.f b/external/w3nco/v2.0.6/src/getgi.f deleted file mode 100644 index 0c47dd706..000000000 --- a/external/w3nco/v2.0.6/src/getgi.f +++ /dev/null @@ -1,88 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGI READS A GRIB INDEX FILE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 95-10-31 -C -C ABSTRACT: READ A GRIB INDEX FILE AND RETURN ITS CONTENTS. -C VERSION 1 OF THE INDEX FILE HAS THE FOLLOWING FORMAT: -C 81-BYTE S.LORD HEADER WITH 'GB1IX1' IN COLUMNS 42-47 FOLLOWED BY -C 81-BYTE HEADER WITH NUMBER OF BYTES TO SKIP BEFORE INDEX RECORDS, -C NUMBER OF BYTES IN EACH INDEX RECORD, NUMBER OF INDEX RECORDS, -C AND GRIB FILE BASENAME WRITTEN IN FORMAT ('IX1FORM:',3I10,2X,A40). -C EACH FOLLOWING INDEX RECORD CORRESPONDS TO A GRIB MESSAGE -C AND HAS THE INTERNAL FORMAT: -C BYTE 001-004: BYTES TO SKIP IN DATA FILE BEFORE GRIB MESSAGE -C BYTE 005-008: BYTES TO SKIP IN MESSAGE BEFORE PDS -C BYTE 009-012: BYTES TO SKIP IN MESSAGE BEFORE GDS (0 IF NO GDS) -C BYTE 013-016: BYTES TO SKIP IN MESSAGE BEFORE BMS (0 IF NO BMS) -C BYTE 017-020: BYTES TO SKIP IN MESSAGE BEFORE BDS -C BYTE 021-024: BYTES TOTAL IN THE MESSAGE -C BYTE 025-025: GRIB VERSION NUMBER -C BYTE 026-053: PRODUCT DEFINITION SECTION (PDS) -C BYTE 054-095: GRID DEFINITION SECTION (GDS) (OR NULLS) -C BYTE 096-101: FIRST PART OF THE BIT MAP SECTION (BMS) (OR NULLS) -C BYTE 102-112: FIRST PART OF THE BINARY DATA SECTION (BDS) -C BYTE 113-172: (OPTIONAL) BYTES 41-100 OF THE PDS -C BYTE 173-184: (OPTIONAL) BYTES 29-40 OF THE PDS -C BYTE 185-320: (OPTIONAL) BYTES 43-178 OF THE GDS -C -C PROGRAM HISTORY LOG: -C 95-10-31 IREDELL -C 96-10-31 IREDELL AUGMENTED OPTIONAL DEFINITIONS TO BYTE 320 -C -C USAGE: CALL GETGI(LUGI,MNUM,MBUF,CBUF,NLEN,NNUM,IRET) -C INPUT ARGUMENTS: -C LUGI INTEGER UNIT OF THE UNBLOCKED GRIB INDEX FILE -C MNUM INTEGER NUMBER OF INDEX RECORDS TO SKIP (USUALLY 0) -C MBUF INTEGER LENGTH OF CBUF IN BYTES -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) BUFFER TO RECEIVE INDEX DATA -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 1 CBUF TOO SMALL TO HOLD INDEX BUFFER -C 2 ERROR READING INDEX FILE BUFFER -C 3 ERROR READING INDEX FILE HEADER -C -C SUBPROGRAMS CALLED: -C BAREAD BYTE-ADDRESSABLE READ -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - CHARACTER CBUF(MBUF) - CHARACTER CHEAD*162 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - NLEN=0 - NNUM=0 - IRET=3 - CALL BAREAD(LUGI,0,162,LHEAD,CHEAD) - IF(LHEAD.EQ.162.AND.CHEAD(42:47).EQ.'GB1IX1') THEN - READ(CHEAD(82:162),'(8X,3I10,2X,A40)',IOSTAT=IOS) NSKP,NLEN,NNUM - IF(IOS.EQ.0) THEN - NSKP=NSKP+MNUM*NLEN - NNUM=NNUM-MNUM - NBUF=NNUM*NLEN - IRET=0 - IF(NBUF.GT.MBUF) THEN - NNUM=MBUF/NLEN - NBUF=NNUM*NLEN - IRET=1 - ENDIF - IF(NBUF.GT.0) THEN - CALL BAREAD(LUGI,NSKP,NBUF,LBUF,CBUF) - IF(LBUF.NE.NBUF) IRET=2 - ENDIF - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/getgir.f b/external/w3nco/v2.0.6/src/getgir.f deleted file mode 100644 index e23871cee..000000000 --- a/external/w3nco/v2.0.6/src/getgir.f +++ /dev/null @@ -1,90 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GETGIR READS A GRIB INDEX FILE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 95-10-31 -C -C ABSTRACT: READ A GRIB FILE AND RETURN ITS INDEX CONTENTS. -C THE INDEX BUFFER RETURNED CONTAINS INDEX RECORDS WITH THE INTERNAL FORMAT: -C BYTE 001-004: BYTES TO SKIP IN DATA FILE BEFORE GRIB MESSAGE -C BYTE 005-008: BYTES TO SKIP IN MESSAGE BEFORE PDS -C BYTE 009-012: BYTES TO SKIP IN MESSAGE BEFORE GDS (0 IF NO GDS) -C BYTE 013-016: BYTES TO SKIP IN MESSAGE BEFORE BMS (0 IF NO BMS) -C BYTE 017-020: BYTES TO SKIP IN MESSAGE BEFORE BDS -C BYTE 021-024: BYTES TOTAL IN THE MESSAGE -C BYTE 025-025: GRIB VERSION NUMBER -C BYTE 026-053: PRODUCT DEFINITION SECTION (PDS) -C BYTE 054-095: GRID DEFINITION SECTION (GDS) (OR NULLS) -C BYTE 096-101: FIRST PART OF THE BIT MAP SECTION (BMS) (OR NULLS) -C BYTE 102-112: FIRST PART OF THE BINARY DATA SECTION (BDS) -C BYTE 113-172: (OPTIONAL) BYTES 41-100 OF THE PDS -C BYTE 173-184: (OPTIONAL) BYTES 29-40 OF THE PDS -C BYTE 185-320: (OPTIONAL) BYTES 43-178 OF THE GDS -C -C PROGRAM HISTORY LOG: -C 95-10-31 IREDELL -C 96-10-31 IREDELL AUGMENTED OPTIONAL DEFINITIONS TO BYTE 320 -C -C USAGE: CALL GETGIR(LUGB,MSK1,MSK2,MNUM,MBUF,CBUF,NLEN,NNUM,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB FILE -C MSK1 INTEGER NUMBER OF BYTES TO SEARCH FOR FIRST MESSAGE -C MSK2 INTEGER NUMBER OF BYTES TO SEARCH FOR OTHER MESSAGES -C MNUM INTEGER NUMBER OF INDEX RECORDS TO SKIP (USUALLY 0) -C MBUF INTEGER LENGTH OF CBUF IN BYTES -C OUTPUT ARGUMENTS: -C CBUF CHARACTER*1 (MBUF) BUFFER TO RECEIVE INDEX DATA -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER NUMBER OF INDEX RECORDS -C (=0 IF NO GRIB MESSAGES ARE FOUND) -C IRET INTEGER RETURN CODE -C 0 ALL OK -C 1 CBUF TOO SMALL TO HOLD INDEX DATA -C -C SUBPROGRAMS CALLED: -C SKGB SEEK NEXT GRIB MESSAGE -C IXGB MAKE INDEX RECORD -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - CHARACTER CBUF(MBUF) - PARAMETER(MINDEX=320) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SEARCH FOR FIRST GRIB MESSAGE - ISEEK=0 - CALL SKGB(LUGB,ISEEK,MSK1,LSKIP,LGRIB) - IF(LGRIB.GT.0.AND.MINDEX.LE.MBUF) THEN - CALL IXGB(LUGB,LSKIP,LGRIB,MINDEX,1,NLEN,CBUF) - ELSE - NLEN=MINDEX - ENDIF - DO M=1,MNUM - IF(LGRIB.GT.0) THEN - ISEEK=LSKIP+LGRIB - CALL SKGB(LUGB,ISEEK,MSK2,LSKIP,LGRIB) - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C MAKE AN INDEX RECORD FOR EVERY GRIB RECORD FOUND - NNUM=0 - IRET=0 - DOWHILE(IRET.EQ.0.AND.LGRIB.GT.0) - IF(NLEN*(NNUM+1).LE.MBUF) THEN - NNUM=NNUM+1 - CALL IXGB(LUGB,LSKIP,LGRIB,NLEN,NNUM,MLEN,CBUF) - ISEEK=LSKIP+LGRIB - CALL SKGB(LUGB,ISEEK,MSK2,LSKIP,LGRIB) - ELSE - IRET=1 - ENDIF - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/gtbits.f b/external/w3nco/v2.0.6/src/gtbits.f deleted file mode 100644 index 8c46e9f49..000000000 --- a/external/w3nco/v2.0.6/src/gtbits.f +++ /dev/null @@ -1,83 +0,0 @@ - SUBROUTINE GTBITS(IBM,IDS,LEN,MG,G,GROUND,GMIN,GMAX,NBIT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: GTBITS COMPUTE NUMBER OF BITS AND ROUND FIELD. -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: THE NUMBER OF BITS REQUIRED TO PACK A GIVEN FIELD -C AT A PARTICULAR DECIMAL SCALING IS COMPUTED USING THE FIELD RANGE. -C THE FIELD IS ROUNDED OFF TO THE DECIMAL SCALING FOR PACKING. -C THE MINIMUM AND MAXIMUM ROUNDED FIELD VALUES ARE ALSO RETURNED. -C GRIB BITMAP MASKING FOR VALID DATA IS OPTIONALLY USED. -C -C PROGRAM HISTORY LOG: -C 92-10-31 IREDELL -C -C USAGE: CALL GTBITS(IBM,IDS,LEN,MG,G,GMIN,GMAX,NBIT) -C INPUT ARGUMENT LIST: -C IBM - INTEGER BITMAP FLAG (=0 FOR NO BITMAP) -C IDS - INTEGER DECIMAL SCALING -C (E.G. IDS=3 TO ROUND FIELD TO NEAREST MILLI-VALUE) -C LEN - INTEGER LENGTH OF THE FIELD AND BITMAP -C MG - INTEGER (LEN) BITMAP IF IBM=1 (0 TO SKIP, 1 TO KEEP) -C G - REAL (LEN) FIELD -C -C OUTPUT ARGUMENT LIST: -C GROUND - REAL (LEN) FIELD ROUNDED TO DECIMAL SCALING -C (SET TO ZERO WHERE BITMAP IS 0 IF IBM=1) -C GMIN - REAL MINIMUM VALID ROUNDED FIELD VALUE -C GMAX - REAL MAXIMUM VALID ROUNDED FIELD VALUE -C NBIT - INTEGER NUMBER OF BITS TO PACK -C -C SUBPROGRAMS CALLED: -C ISRCHNE - FIND FIRST VALUE IN AN ARRAY NOT EQUAL TO TARGET VALUE -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - DIMENSION MG(LEN),G(LEN),GROUND(LEN) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C ROUND FIELD AND DETERMINE EXTREMES WHERE BITMAP IS ON - DS=10.**IDS - IF(IBM.EQ.0) THEN - GROUND(1)=NINT(G(1)*DS)/DS - GMAX=GROUND(1) - GMIN=GROUND(1) - DO I=2,LEN - GROUND(I)=NINT(G(I)*DS)/DS - GMAX=MAX(GMAX,GROUND(I)) - GMIN=MIN(GMIN,GROUND(I)) - ENDDO - ELSE - I1=ISRCHNE(LEN,MG,1,0) - IF(I1.GT.0.AND.I1.LE.LEN) THEN - DO I=1,I1-1 - GROUND(I)=0. - ENDDO - GROUND(I1)=NINT(G(I1)*DS)/DS - GMAX=GROUND(I1) - GMIN=GROUND(I1) - DO I=I1+1,LEN - IF(MG(I).NE.0) THEN - GROUND(I)=NINT(G(I)*DS)/DS - GMAX=MAX(GMAX,GROUND(I)) - GMIN=MIN(GMIN,GROUND(I)) - ELSE - GROUND(I)=0. - ENDIF - ENDDO - ELSE - DO I=1,LEN - GROUND(I)=0. - ENDDO - GMAX=0. - GMIN=0. - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COMPUTE NUMBER OF BITS - NBIT=LOG((GMAX-GMIN)*DS+0.9)/LOG(2.)+1. -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/idsdef.f b/external/w3nco/v2.0.6/src/idsdef.f deleted file mode 100644 index ca8862c9a..000000000 --- a/external/w3nco/v2.0.6/src/idsdef.f +++ /dev/null @@ -1,285 +0,0 @@ - SUBROUTINE IDSDEF(IPTV,IDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: IDSDEF SETS DEFAULT DECIMAL SCALINGS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: SETS DECIMAL SCALINGS DEFAULTS FOR VARIOUS PARAMETERS. -C A DECIMAL SCALING OF -3 MEANS DATA IS PACKED IN KILO-SI UNITS. -C -C PROGRAM HISTORY LOG: -C 92-10-31 IREDELL -C -C USAGE: CALL IDSDEF(IPTV,IDS) -C INPUT ARGUMENTS: -C IPTV PARAMTER TABLE VERSION (ONLY 1 OR 2 IS RECOGNIZED) -C OUTPUT ARGUMENTS: -C IDS INTEGER (255) DECIMAL SCALINGS -C (UNKNOWN DECIMAL SCALINGS WILL NOT BE SET) -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - DIMENSION IDS(255) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - IF(IPTV.EQ.1.OR.IPTV.EQ.2) THEN - IDS(001)=-1 ! PRESSURE (PA) - IDS(002)=-1 ! SEA-LEVEL PRESSURE (PA) - IDS(003)=3 ! PRESSURE TENDENCY (PA/S) - ! - ! - IDS(006)=-1 ! GEOPOTENTIAL (M2/S2) - IDS(007)=0 ! GEOPOTENTIAL HEIGHT (M) - IDS(008)=0 ! GEOMETRIC HEIGHT (M) - IDS(009)=0 ! STANDARD DEVIATION OF HEIGHT (M) - ! - IDS(011)=1 ! TEMPERATURE (K) - IDS(012)=1 ! VIRTUAL TEMPERATURE (K) - IDS(013)=1 ! POTENTIAL TEMPERATURE (K) - IDS(014)=1 ! PSEUDO-ADIABATIC POTENTIAL TEMPERATURE (K) - IDS(015)=1 ! MAXIMUM TEMPERATURE (K) - IDS(016)=1 ! MINIMUM TEMPERATURE (K) - IDS(017)=1 ! DEWPOINT TEMPERATURE (K) - IDS(018)=1 ! DEWPOINT DEPRESSION (K) - IDS(019)=4 ! TEMPERATURE LAPSE RATE (K/M) - IDS(020)=0 ! VISIBILITY (M) - ! RADAR SPECTRA 1 () - ! RADAR SPECTRA 2 () - ! RADAR SPECTRA 3 () - ! - IDS(025)=1 ! TEMPERATURE ANOMALY (K) - IDS(026)=-1 ! PRESSURE ANOMALY (PA) - IDS(027)=0 ! GEOPOTENTIAL HEIGHT ANOMALY (M) - ! WAVE SPECTRA 1 () - ! WAVE SPECTRA 2 () - ! WAVE SPECTRA 3 () - IDS(031)=0 ! WIND DIRECTION (DEGREES) - IDS(032)=1 ! WIND SPEED (M/S) - IDS(033)=1 ! ZONAL WIND (M/S) - IDS(034)=1 ! MERIDIONAL WIND (M/S) - IDS(035)=-4 ! STREAMFUNCTION (M2/S) - IDS(036)=-4 ! VELOCITY POTENTIAL (M2/S) - IDS(037)=-1 ! MONTGOMERY STREAM FUNCTION (M2/S2) - IDS(038)=8 ! SIGMA VERTICAL VELOCITY (1/S) - IDS(039)=3 ! PRESSURE VERTICAL VELOCITY (PA/S) - IDS(040)=4 ! GEOMETRIC VERTICAL VELOCITY (M/S) - IDS(041)=6 ! ABSOLUTE VORTICITY (1/S) - IDS(042)=6 ! ABSOLUTE DIVERGENCE (1/S) - IDS(043)=6 ! RELATIVE VORTICITY (1/S) - IDS(044)=6 ! RELATIVE DIVERGENCE (1/S) - IDS(045)=4 ! VERTICAL U SHEAR (1/S) - IDS(046)=4 ! VERTICAL V SHEAR (1/S) - IDS(047)=0 ! DIRECTION OF CURRENT (DEGREES) - ! SPEED OF CURRENT (M/S) - ! U OF CURRENT (M/S) - ! V OF CURRENT (M/S) - IDS(051)=4 ! SPECIFIC HUMIDITY (KG/KG) - IDS(052)=0 ! RELATIVE HUMIDITY (PERCENT) - IDS(053)=4 ! HUMIDITY MIXING RATIO (KG/KG) - IDS(054)=1 ! PRECIPITABLE WATER (KG/M2) - IDS(055)=-1 ! VAPOR PRESSURE (PA) - IDS(056)=-1 ! SATURATION DEFICIT (PA) - IDS(057)=1 ! EVAPORATION (KG/M2) - IDS(058)=1 ! CLOUD ICE (KG/M2) - IDS(059)=6 ! PRECIPITATION RATE (KG/M2/S) - IDS(060)=0 ! THUNDERSTORM PROBABILITY (PERCENT) - IDS(061)=1 ! TOTAL PRECIPITATION (KG/M2) - IDS(062)=1 ! LARGE-SCALE PRECIPITATION (KG/M2) - IDS(063)=1 ! CONVECTIVE PRECIPITATION (KG/M2) - IDS(064)=6 ! WATER EQUIVALENT SNOWFALL RATE (KG/M2/S) - IDS(065)=0 ! WATER EQUIVALENT OF SNOW DEPTH (KG/M2) - IDS(066)=2 ! SNOW DEPTH (M) - ! MIXED-LAYER DEPTH (M) - ! TRANSIENT THERMOCLINE DEPTH (M) - ! MAIN THERMOCLINE DEPTH (M) - ! MAIN THERMOCLINE ANOMALY (M) - IDS(071)=0 ! TOTAL CLOUD COVER (PERCENT) - IDS(072)=0 ! CONVECTIVE CLOUD COVER (PERCENT) - IDS(073)=0 ! LOW CLOUD COVER (PERCENT) - IDS(074)=0 ! MIDDLE CLOUD COVER (PERCENT) - IDS(075)=0 ! HIGH CLOUD COVER (PERCENT) - IDS(076)=1 ! CLOUD WATER (KG/M2) - ! - IDS(078)=1 ! CONVECTIVE SNOW (KG/M2) - IDS(079)=1 ! LARGE SCALE SNOW (KG/M2) - IDS(080)=1 ! WATER TEMPERATURE (K) - IDS(081)=0 ! SEA-LAND MASK () - ! DEVIATION OF SEA LEVEL FROM MEAN (M) - IDS(083)=5 ! ROUGHNESS (M) - IDS(084)=1 ! ALBEDO (PERCENT) - IDS(085)=1 ! SOIL TEMPERATURE (K) - IDS(086)=0 ! SOIL WETNESS (KG/M2) - IDS(087)=0 ! VEGETATION (PERCENT) - ! SALINITY (KG/KG) - IDS(089)=4 ! DENSITY (KG/M3) - IDS(090)=1 ! RUNOFF (KG/M2) - IDS(091)=0 ! ICE CONCENTRATION () - ! ICE THICKNESS (M) - IDS(093)=0 ! DIRECTION OF ICE DRIFT (DEGREES) - ! SPEED OF ICE DRIFT (M/S) - ! U OF ICE DRIFT (M/S) - ! V OF ICE DRIFT (M/S) - ! ICE GROWTH (M) - ! ICE DIVERGENCE (1/S) - IDS(099)=1 ! SNOW MELT (KG/M2) - ! SIG HEIGHT OF WAVES AND SWELL (M) - IDS(101)=0 ! DIRECTION OF WIND WAVES (DEGREES) - ! SIG HEIGHT OF WIND WAVES (M) - ! MEAN PERIOD OF WIND WAVES (S) - IDS(104)=0 ! DIRECTION OF SWELL WAVES (DEGREES) - ! SIG HEIGHT OF SWELL WAVES (M) - ! MEAN PERIOD OF SWELL WAVES (S) - IDS(107)=0 ! PRIMARY WAVE DIRECTION (DEGREES) - ! PRIMARY WAVE MEAN PERIOD (S) - IDS(109)=0 ! SECONDARY WAVE DIRECTION (DEGREES) - ! SECONDARY WAVE MEAN PERIOD (S) - IDS(111)=0 ! NET SOLAR RADIATIVE FLUX AT SURFACE (W/M2) - IDS(112)=0 ! NET LONGWAVE RADIATIVE FLUX AT SURFACE (W/M2) - IDS(113)=0 ! NET SOLAR RADIATIVE FLUX AT TOP (W/M2) - IDS(114)=0 ! NET LONGWAVE RADIATIVE FLUX AT TOP (W/M2) - IDS(115)=0 ! NET LONGWAVE RADIATIVE FLUX (W/M2) - IDS(116)=0 ! NET SOLAR RADIATIVE FLUX (W/M2) - IDS(117)=0 ! TOTAL RADIATIVE FLUX (W/M2) - ! - ! - ! - IDS(121)=0 ! LATENT HEAT FLUX (W/M2) - IDS(122)=0 ! SENSIBLE HEAT FLUX (W/M2) - IDS(123)=0 ! BOUNDARY LAYER DISSIPATION (W/M2) - IDS(124)=3 ! U WIND STRESS (N/M2) - IDS(125)=3 ! V WIND STRESS (N/M2) - ! WIND MIXING ENERGY (J) - ! IMAGE DATA () - IDS(128)=-1 ! MEAN SEA-LEVEL PRESSURE (STDATM) (PA) - IDS(129)=-1 ! MEAN SEA-LEVEL PRESSURE (MAPS) (PA) - IDS(130)=-1 ! MEAN SEA-LEVEL PRESSURE (ETA) (PA) - IDS(131)=1 ! SURFACE LIFTED INDEX (K) - IDS(132)=1 ! BEST LIFTED INDEX (K) - IDS(133)=1 ! K INDEX (K) - IDS(134)=1 ! SWEAT INDEX (K) - IDS(135)=10 ! HORIZONTAL MOISTURE DIVERGENCE (KG/KG/S) - IDS(136)=4 ! SPEED SHEAR (1/S) - IDS(137)=3 ! 3-HR PRESSURE TENDENCY (PA/S) - IDS(138)=6 ! BRUNT-VAISALA FREQUENCY SQUARED (1/S2) - IDS(139)=11 ! POTENTIAL VORTICITY (MASS-WEIGHTED) (1/S/M) - IDS(140)=0 ! RAIN MASK () - IDS(141)=0 ! FREEZING RAIN MASK () - IDS(142)=0 ! ICE PELLETS MASK () - IDS(143)=0 ! SNOW MASK () - IDS(144)=3 ! VOLUMETRIC SOIL MOISTURE CONTENT (FRACTION) - IDS(145)=0 ! POTENTIAL EVAPORATION RATE (W/M2) - IDS(146)=0 ! CLOUD WORKFUNCTION (J/KG) - IDS(147)=3 ! U GRAVITY WAVE STRESS (N/M2) - IDS(148)=3 ! V GRAVITY WAVE STRESS (N/M2) - IDS(149)=10 ! POTENTIAL VORTICITY (M2/S/KG) - ! COVARIANCE BETWEEN V AND U (M2/S2) - ! COVARIANCE BETWEEN U AND T (K*M/S) - ! COVARIANCE BETWEEN V AND T (K*M/S) - ! - ! - IDS(155)=0 ! GROUND HEAT FLUX (W/M2) - IDS(156)=0 ! CONVECTIVE INHIBITION (W/M2) - IDS(157)=0 ! CONVECTIVE APE (J/KG) - IDS(158)=0 ! TURBULENT KE (J/KG) - IDS(159)=-1 ! CONDENSATION PRESSURE OF LIFTED PARCEL (PA) - IDS(160)=0 ! CLEAR SKY UPWARD SOLAR FLUX (W/M2) - IDS(161)=0 ! CLEAR SKY DOWNWARD SOLAR FLUX (W/M2) - IDS(162)=0 ! CLEAR SKY UPWARD LONGWAVE FLUX (W/M2) - IDS(163)=0 ! CLEAR SKY DOWNWARD LONGWAVE FLUX (W/M2) - IDS(164)=0 ! CLOUD FORCING NET SOLAR FLUX (W/M2) - IDS(165)=0 ! CLOUD FORCING NET LONGWAVE FLUX (W/M2) - IDS(166)=0 ! VISIBLE BEAM DOWNWARD SOLAR FLUX (W/M2) - IDS(167)=0 ! VISIBLE DIFFUSE DOWNWARD SOLAR FLUX (W/M2) - IDS(168)=0 ! NEAR IR BEAM DOWNWARD SOLAR FLUX (W/M2) - IDS(169)=0 ! NEAR IR DIFFUSE DOWNWARD SOLAR FLUX (W/M2) - ! - ! - IDS(172)=3 ! MOMENTUM FLUX (N/M2) - IDS(173)=0 ! MASS POINT MODEL SURFACE () - IDS(174)=0 ! VELOCITY POINT MODEL SURFACE () - IDS(175)=0 ! SIGMA LAYER NUMBER () - IDS(176)=2 ! LATITUDE (DEGREES) - IDS(177)=2 ! EAST LONGITUDE (DEGREES) - ! - ! - ! - IDS(181)=9 ! X-GRADIENT LOG PRESSURE (1/M) - IDS(182)=9 ! Y-GRADIENT LOG PRESSURE (1/M) - IDS(183)=5 ! X-GRADIENT HEIGHT (M/M) - IDS(184)=5 ! Y-GRADIENT HEIGHT (M/M) - ! - ! - ! - ! - ! - ! - ! - ! - ! - ! - ! - ! - ! - ! - ! - ! - IDS(201)=0 ! ICE-FREE WATER SURCACE (PERCENT) - ! - ! - IDS(204)=0 ! DOWNWARD SOLAR RADIATIVE FLUX (W/M2) - IDS(205)=0 ! DOWNWARD LONGWAVE RADIATIVE FLUX (W/M2) - ! - IDS(207)=0 ! MOISTURE AVAILABILITY (PERCENT) - ! EXCHANGE COEFFICIENT (KG/M2/S) - IDS(209)=0 ! NUMBER OF MIXED LAYER NEXT TO SFC () - ! - IDS(211)=0 ! UPWARD SOLAR RADIATIVE FLUX (W/M2) - IDS(212)=0 ! UPWARD LONGWAVE RADIATIVE FLUX (W/M2) - IDS(213)=0 ! NON-CONVECTIVE CLOUD COVER (PERCENT) - IDS(214)=6 ! CONVECTIVE PRECIPITATION RATE (KG/M2/S) - IDS(215)=7 ! TOTAL DIABATIC HEATING RATE (K/S) - IDS(216)=7 ! TOTAL RADIATIVE HEATING RATE (K/S) - IDS(217)=7 ! TOTAL DIABATIC NONRADIATIVE HEATING RATE (K/S) - IDS(218)=2 ! PRECIPITATION INDEX (FRACTION) - IDS(219)=1 ! STD DEV OF IR T OVER 1X1 DEG AREA (K) - IDS(220)=4 ! NATURAL LOG OF SURFACE PRESSURE OVER 1 KPA () - ! - IDS(222)=0 ! 5-WAVE GEOPOTENTIAL HEIGHT (M) - IDS(223)=1 ! PLANT CANOPY SURFACE WATER (KG/M2) - ! - ! - ! BLACKADARS MIXING LENGTH (M) - ! ASYMPTOTIC MIXING LENGTH (M) - IDS(228)=1 ! POTENTIAL EVAPORATION (KG/M2) - IDS(229)=0 ! SNOW PHASE-CHANGE HEAT FLUX (W/M2) - ! - IDS(231)=3 ! CONVECTIVE CLOUD MASS FLUX (PA/S) - IDS(232)=0 ! DOWNWARD TOTAL RADIATION FLUX (W/M2) - IDS(233)=0 ! UPWARD TOTAL RADIATION FLUX (W/M2) - IDS(224)=1 ! BASEFLOW-GROUNDWATER RUNOFF (KG/M2) - IDS(225)=1 ! STORM SURFACE RUNOFF (KG/M2) - ! - ! - IDS(238)=0 ! SNOW COVER (PERCENT) - IDS(239)=1 ! SNOW TEMPERATURE (K) - ! - IDS(241)=7 ! LARGE SCALE CONDENSATION HEATING RATE (K/S) - IDS(242)=7 ! DEEP CONVECTIVE HEATING RATE (K/S) - IDS(243)=10 ! DEEP CONVECTIVE MOISTENING RATE (KG/KG/S) - IDS(244)=7 ! SHALLOW CONVECTIVE HEATING RATE (K/S) - IDS(245)=10 ! SHALLOW CONVECTIVE MOISTENING RATE (KG/KG/S) - IDS(246)=7 ! VERTICAL DIFFUSION HEATING RATE (KG/KG/S) - IDS(247)=7 ! VERTICAL DIFFUSION ZONAL ACCELERATION (M/S/S) - IDS(248)=7 ! VERTICAL DIFFUSION MERID ACCELERATION (M/S/S) - IDS(249)=10 ! VERTICAL DIFFUSION MOISTENING RATE (KG/KG/S) - IDS(250)=7 ! SOLAR RADIATIVE HEATING RATE (K/S) - IDS(251)=7 ! LONGWAVE RADIATIVE HEATING RATE (K/S) - ! DRAG COEFFICIENT () - ! FRICTION VELOCITY (M/S) - ! RICHARDSON NUMBER () - ! - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/instrument.f b/external/w3nco/v2.0.6/src/instrument.f deleted file mode 100644 index 0c936f994..000000000 --- a/external/w3nco/v2.0.6/src/instrument.f +++ /dev/null @@ -1,111 +0,0 @@ -!----------------------------------------------------------------------- - SUBROUTINE INSTRUMENT(K,KALL,TTOT,TMIN,TMAX) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! . . . . -! SUBPROGRAM: INSTRUMENT MONITOR WALL-CLOCK TIMES, ETC. -! PRGMMR: IREDELL ORG: NP23 DATE:1998-07-16 -! -! ABSTRACT: THIS SUBPROGRAM IS USEFUL IN INSTRUMENTING A CODE -! BY MONITORING THE NUMBER OF TIMES EACH GIVEN SECTION -! OF A PROGRAM IS INVOKED AS WELL AS THE MINIMUM, MAXIMUM -! AND TOTAL WALL-CLOCK TIME SPENT IN THE GIVEN SECTION. -! -! PROGRAM HISTORY LOG: -! 1998-07-16 IREDELL -! -! USAGE: CALL INSTRUMENT(K,KALL,TTOT,TMIN,TMAX) -! INPUT ARGUMENT LIST: -! K - INTEGER POSITIVE SECTION NUMBER -! OR MAXIMUM SECTION NUMBER IN THE FIRST INVOCATION -! OR ZERO TO RESET ALL WALL-CLOCK STATISTICS -! OR NEGATIVE SECTION NUMBER TO SKIP MONITORING -! AND JUST RETURN STATISTICS. -! -! OUTPUT ARGUMENT LIST: -! KALL - INTEGER NUMBER OF TIMES SECTION IS CALLED -! TTOT - REAL TOTAL SECONDS SPENT IN SECTION -! TMIN - REAL MINIMUM SECONDS SPENT IN SECTION -! TMAX - REAL MAXIMUM SECONDS SPENT IN SECTION -! -! SUBPROGRAMS CALLED: -! W3UTCDAT RETURN THE UTC DATE AND TIME -! W3DIFDAT RETURN A TIME INTERVAL BETWEEN TWO DATES -! -! REMARKS: -! THIS SUBPROGRAM SHOULD NOT BE INVOKED FROM A MULTITASKING REGION. -! NORMALLY, TIME SPENT INSIDE THIS SUBPROGRAM IS NOT COUNTED. -! WALL-CLOCK TIMES ARE KEPT TO THE NEAREST MILLISECOND. -! -! EXAMPLE. -! CALL INSTRUMENT(2,KALL,TTOT,TMIN,TMAX) ! KEEP STATS FOR 2 SUBS -! DO K=1,N -! CALL SUB1 -! CALL INSTRUMENT(1,KALL,TTOT,TMIN,TMAX) ! ACCUM STATS FOR SUB1 -! CALL SUB2 -! CALL INSTRUMENT(2,KALL,TTOT,TMIN,TMAX) ! ACCUM STATS FOR SUB2 -! ENDDO -! PRINT *,'SUB2 STATS: ',KALL,TTOT,TMIN,TMAX -! CALL INSTRUMENT(-1,KALL,TTOT,TMIN,TMAX) ! RETURN STATS FOR SUB1 -! PRINT *,'SUB1 STATS: ',KALL,TTOT,TMIN,TMAX -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - IMPLICIT NONE - INTEGER,INTENT(IN):: K - INTEGER,INTENT(OUT):: KALL - REAL,INTENT(OUT):: TTOT,TMIN,TMAX - INTEGER,SAVE:: KMAX=0 - INTEGER,DIMENSION(:),ALLOCATABLE,SAVE:: KALLS - REAL,DIMENSION(:),ALLOCATABLE,SAVE:: TTOTS,TMINS,TMAXS - INTEGER,DIMENSION(8),SAVE:: IDAT - INTEGER,DIMENSION(8):: JDAT - REAL,DIMENSION(5):: RINC - INTEGER:: KA -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - KA=ABS(K) -! ALLOCATE MONITORING ARRAYS IF INITIAL INVOCATION - IF(KMAX.EQ.0) THEN - KMAX=K - ALLOCATE(KALLS(KMAX)) - ALLOCATE(TTOTS(KMAX)) - ALLOCATE(TMINS(KMAX)) - ALLOCATE(TMAXS(KMAX)) - KALLS=0 - KA=0 -! OR RESET ALL STATISTICS BACK TO ZERO - ELSEIF(K.EQ.0) THEN - KALLS=0 -! OR COUNT TIME SINCE LAST INVOCATION AGAINST THIS SECTION - ELSEIF(K.GT.0) THEN - CALL W3UTCDAT(JDAT) - CALL W3DIFDAT(JDAT,IDAT,4,RINC) - KALLS(K)=KALLS(K)+1 - IF(KALLS(K).EQ.1) THEN - TTOTS(K)=RINC(4) - TMINS(K)=RINC(4) - TMAXS(K)=RINC(4) - ELSE - TTOTS(K)=TTOTS(K)+RINC(4) - TMINS(K)=MIN(TMINS(K),RINC(4)) - TMAXS(K)=MAX(TMAXS(K),RINC(4)) - ENDIF - ENDIF -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! RETURN STATISTICS - IF(KA.GE.1.AND.KA.LE.KMAX.AND.KALLS(KA).GT.0) THEN - KALL=KALLS(KA) - TTOT=TTOTS(KA) - TMIN=TMINS(KA) - TMAX=TMAXS(KA) - ELSE - KALL=0 - TTOT=0 - TMIN=0 - TMAX=0 - ENDIF -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! KEEP CURRENT TIME FOR NEXT INVOCATION - IF(K.GE.0) CALL W3UTCDAT(IDAT) - END SUBROUTINE INSTRUMENT diff --git a/external/w3nco/v2.0.6/src/iw3jdn.f b/external/w3nco/v2.0.6/src/iw3jdn.f deleted file mode 100644 index 896d62114..000000000 --- a/external/w3nco/v2.0.6/src/iw3jdn.f +++ /dev/null @@ -1,62 +0,0 @@ - FUNCTION IW3JDN(IYEAR,MONTH,IDAY) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: IW3JDN COMPUTE JULIAN DAY NUMBER -C AUTHOR: JONES,R.E. ORG: W342 DATE: 87-03-29 -C -C ABSTRACT: COMPUTES JULIAN DAY NUMBER FROM YEAR (4 DIGITS), MONTH, -C AND DAY. IW3JDN IS VALID FOR YEARS 1583 A.D. TO 3300 A.D. -C JULIAN DAY NUMBER CAN BE USED TO COMPUTE DAY OF WEEK, DAY OF -C YEAR, RECORD NUMBERS IN AN ARCHIVE, REPLACE DAY OF CENTURY, -C FIND THE NUMBER OF DAYS BETWEEN TWO DATES. -C -C PROGRAM HISTORY LOG: -C 87-03-29 R.E.JONES -C 89-10-25 R.E.JONES CONVERT TO CRAY CFT77 FORTRAN -C -C USAGE: II = IW3JDN(IYEAR,MONTH,IDAY) -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C IYEAR ARG LIST INTEGER YEAR ( 4 DIGITS) -C MONTH ARG LIST INTEGER MONTH OF YEAR (1 - 12) -C IDAY ARG LIST INTEGER DAY OF MONTH (1 - 31) -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C IW3JDN FUNTION INTEGER JULIAN DAY NUMBER -C JAN. 1,1960 IS JULIAN DAY NUMBER 2436935 -C JAN. 1,1987 IS JULIAN DAY NUMBER 2446797 -C -C REMARKS: JULIAN PERIOD WAS DEVISED BY JOSEPH SCALIGER IN 1582. -C JULIAN DAY NUMBER #1 STARTED ON JAN. 1,4713 B.C. THREE MAJOR -C CHRONOLOGICAL CYCLES BEGIN ON THE SAME DAY. A 28-YEAR SOLAR -C CYCLE, A 19-YEAR LUNER CYCLE, A 15-YEAR INDICTION CYCLE, USED -C IN ANCIENT ROME TO REGULATE TAXES. IT WILL TAKE 7980 YEARS -C TO COMPLETE THE PERIOD, THE PRODUCT OF 28, 19, AND 15. -C SCALIGER NAMED THE PERIOD, DATE, AND NUMBER AFTER HIS FATHER -C JULIUS (NOT AFTER THE JULIAN CALENDAR). THIS SEEMS TO HAVE -C CAUSED A LOT OF CONFUSION IN TEXT BOOKS. SCALIGER NAME IS -C SPELLED THREE DIFFERENT WAYS. JULIAN DATE AND JULIAN DAY -C NUMBER ARE INTERCHANGED. A JULIAN DATE IS USED BY ASTRONOMERS -C TO COMPUTE ACCURATE TIME, IT HAS A FRACTION. WHEN TRUNCATED TO -C AN INTEGER IT IS CALLED AN JULIAN DAY NUMBER. THIS FUNCTION -C WAS IN A LETTER TO THE EDITOR OF THE COMMUNICATIONS OF THE ACM -C VOLUME 11 / NUMBER 10 / OCTOBER 1968. THE JULIAN DAY NUMBER -C CAN BE CONVERTED TO A YEAR, MONTH, DAY, DAY OF WEEK, DAY OF -C YEAR BY CALLING SUBROUTINE W3FS26. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/864, CRAY Y-MP EL2/256 -C -C$$$ -C - IW3JDN = IDAY - 32075 - & + 1461 * (IYEAR + 4800 + (MONTH - 14) / 12) / 4 - & + 367 * (MONTH - 2 - (MONTH -14) / 12 * 12) / 12 - & - 3 * ((IYEAR + 4900 + (MONTH - 14) / 12) / 100) / 4 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/iw3pds.f b/external/w3nco/v2.0.6/src/iw3pds.f deleted file mode 100644 index 103beb685..000000000 --- a/external/w3nco/v2.0.6/src/iw3pds.f +++ /dev/null @@ -1,177 +0,0 @@ - LOGICAL FUNCTION IW3PDS(L1, L2, KEY) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C FUNCTION: IW3PDS TEST FOR MATCH OF TWO PDS -C AUTHOR: JONES, R.E. ORG: W342 DATE: 88-02-22 -C -C ABSTACT: TEST TWO PDS (GRIB PRODUCT DEFINITION SECTION) TO SEE -C IF ALL EQUAL; OTHERWISE .FALSE. IF KEY = 1, ALL 24 CHARACTERS -C ARE TESTED, IF KEY = 0 , THE DATE (CHARACTERS 13-17) ARE NOT -C TESTED. IF KEY = 2, 11 OF 1ST 12 BYTES ARE TESTED. BYTE 4 IS -C IS NOT TESTED, SO TABLE VERSION NUMBER CAN CHANGE AND YOUR -C PROGRAM WILL STILL WORK. IF KEY=3, TEST BYTES 1-3, 7-12. -C -C PROGRAM HISTORY LOG: -C 88-02-22 R.E.JONES -C 89-08-29 R.E.JONES ADD ENTRY IW3PDS, AN ALIAS NAME. -C 89-08-29 R.E.JONES CHANGE TO CRAY CFT77 FORTRAN, MAKE IW3PDS -C THE FUNCTION NAME, IW3PDB THE ALIAS. -C 94-02-10 R.E.JONES ADD KEY=2, TEST ONLY 11 OF 1ST 12 BYTES. -C BYTE 4 (TABLE VERSION NO.) IS NOT TESTED -C 94-07-07 R.E.JONES ADD KEY=3, TEST BYTES 1-3, 7-12. -C -C USAGE: II = IW3PDS(L1,L2,KEY) -C II = IW3PDB(L1,L2,KEY) ALIAS -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C L1 ARG LIST CHARACTER ARRAY TO MATCH WITH L2, -C L1 CAN ALSO BE A 3 WORD INTEGER ARRAY -C L2 ARG LIST CHARACTER ARRAY TO MATCH WITH L1, -C L2 CAN ALSO BE A 3 WORD INTEGER ARRAY -C KEY ARG LIST 0, DO NOT INCLUDE THE DATE (BYTES 13-17) IN -C MATCH. -C 1, MATCH 24 BYTES OF PDS -C 2, MATCH BYTES 1-3, 5-12 OF PDS -C 3, MATCH BYTES 1-3, 7-12 OF PDS -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C IW3PDB FUNCTION LOGICAL .TRUE. IF L1 AND L2 MATCH ON ALL CHAR., -C LOGICAL .FALSE. IF NOT MATCH ON ANY CHAR. -C -C EXAMPLE: SEARCH IDTBL FOR MATCH WITH GIVEN (PDS), USE RBA IN 7TH -C ID WORD TO READ RECORD BY RBA. -C -C INTEGER IDTBL(1794), IPDS(6), RBA -C LOGICAL IW3PDS -C -C KEY = 0 -C DO 400 I = 9,1793,7 -C IF (IDTBL(I).EQ.0) GO TO 500 -C IF (IW3PDS(IPDS,IDTBL(I),KEY)) THEN -C RBA = IDTBL(I+6) -C GO TO 600 -C END IF -C 400 CONTINUE -C -C 500 CONTINUE -C GO TO XXXX ... ERROR EXIT , CAN NOT FIND RECORD -C -C 600 .. READ RECORD WITH RBA -C -C REMARK: ALIAS ADDED BECAUSE OF NAME CHANGE IN GRIB WRITE UP. -C NAME OF PDB (PRODUCT DEFINITION BLOCK) WAS CHANGD TO PDS -C (PRODUCT DEFINITION SECTION). -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916-128, CRAY Y-MP8/864, CRAY Y-MP EL2/256 -C -C$$$ -C - CHARACTER*1 L1(24) - CHARACTER*1 L2(24) -C - LOGICAL IW3PDB -C - SAVE -C - IW3PDS = .TRUE. -C - IF (KEY.EQ.1) THEN - DO 10 I = 1,3 - IF (L1(I).NE.L2(I)) GO TO 70 - 10 CONTINUE -C - DO 20 I = 5,24 - IF (L1(I).NE.L2(I)) GO TO 70 - 20 CONTINUE -C - ELSE -C - DO 30 I = 1,3 - IF (L1(I).NE.L2(I)) GO TO 70 - 30 CONTINUE -C -C DO NOT TEST BYTE 4, 5, 6 PDS VER. NO., COUNTRY -C MODEL NUMBER. U.S., U.K., FNOC WAFS DATA WILL -C WORK. -C - IF (KEY.EQ.3) THEN - DO I = 7,12 - IF (L1(I).NE.L2(I)) GO TO 70 - END DO - GO TO 60 - END IF -C -C DO NOT TEST PDS VERSION NUMBER, IT MAY BE 1 O 2 -C - DO 40 I = 5,12 - IF (L1(I).NE.L2(I)) GO TO 70 - 40 CONTINUE - IF (KEY.EQ.2) GO TO 60 -C - DO 50 I = 18,24 - IF (L1(I).NE.L2(I)) GO TO 70 - 50 CONTINUE - ENDIF -C - 60 CONTINUE - RETURN -C - 70 CONTINUE - IW3PDS = .FALSE. - RETURN -C - ENTRY IW3PDB (L1, L2, KEY) -C - IW3PDB = .TRUE. -C - IF (KEY.EQ.1) THEN - DO 80 I = 1,3 - IF (L1(I).NE.L2(I)) GO TO 140 - 80 CONTINUE -C - DO 90 I = 5,24 - IF (L1(I).NE.L2(I)) GO TO 140 - 90 CONTINUE -C - ELSE -C - DO 100 I = 1,3 - IF (L1(I).NE.L2(I)) GO TO 140 - 100 CONTINUE -C -C DO NOT TEST BYTE 4, 5, 6 PDS VER. NO., COUNTRY -C MODEL NUMBER. U.S., U.K., FNOC WAFS DATA WILL -C WORK. -C - IF (KEY.EQ.3) THEN - DO I = 7,12 - IF (L1(I).NE.L2(I)) GO TO 140 - END DO - GO TO 130 - END IF -C -C DO NOT TEST PDS VERSION NUMBER, IT MAY BE 1 O 2 -C - DO 110 I = 5,12 - IF (L1(I).NE.L2(I)) GO TO 140 - 110 CONTINUE - IF (KEY.EQ.2) GO TO 130 -C - DO 120 I = 18,24 - IF (L1(I).NE.L2(I)) GO TO 140 - 120 CONTINUE - ENDIF -C - 130 CONTINUE - RETURN -C - 140 CONTINUE - IW3PDB = .FALSE. - RETURN - END diff --git a/external/w3nco/v2.0.6/src/iw3unp29.f b/external/w3nco/v2.0.6/src/iw3unp29.f deleted file mode 100644 index 352598aa0..000000000 --- a/external/w3nco/v2.0.6/src/iw3unp29.f +++ /dev/null @@ -1,4656 +0,0 @@ -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: IW3UNP29 -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 2013-03-20 -C -C********************************************************************** -C********************************************************************** -C NOTICE: -C This routine has not been tested reading input data from any dump -C type in ON29/124 format on WCOSS. It likely will not work when -C attempting to read ON29/124 format dumps on WCOSS. It has also -C not been tested reading any dump file other than ADPUPA (BUFR -C input only) on WCOSS. It does work reading BUFR ADPUPA dump files -C on WCOSS. It will hopefully working reading other BUFR (only) -C dump files on WCOSS. -C -C Also, this routine is only known to work correctly when compiled -C using 8 byte machine words (real and integer). -C********************************************************************** -C********************************************************************** -C -C ABSTRACT: READS AND UNPACKS ONE REPORT INTO THE UNPACKED OFFICE NOTE -C 29/124 FORMAT. THE INPUT DATA MAY BE PACKED INTO EITHER BUFR OR -C TRUE ON29/124 FORMAT WITH A Y2K COMPLIANT PSEUDO-ON85 HEADER LABEL. -C (NOTE: AS A TEMPORARY MEASURE, THIS CODE WILL STILL OPERATE ON A -C TRUE ON29/124 FORMAT FILE WITH A NON-Y2K COMPLIANT ON85 HEADER -C LABEL. THE CODE WILL USE THE "WINDOWING" TECHNIQUE TO OBTAIN A -C 4-DIGIT YEAR.) THIS ROUTINE WILL DETERMINE THE FORMAT OF THE -C INPUT DATA AND TAKE THE APPROPRIATE ACTION. IT RETURNS THE -C UNPACKED REPORT TO THE CALLING PROGRAM IN THE ARRAY 'OBS'. -C VARIOUS CONTINGENCIES ARE COVERED BY RETURN VALUE OF THE FUNCTION -C AND PARAMETER 'IER' - FUNCTION AND IER HAVE SAME VALUE. REPEATED -C CALLS OF FUNCTION WILL RETURN A SEQUENCE OF UNPACKED ON29/124 -C REPORTS. THE CALLING PROGRAM MAY SWITCH TO A NEW 'NUNIT' AT ANY -C TIME, THAT DATASET WILL THEN BE READ IN SEQUENCE. IF USER -C SWITCHES BACK TO A PREVIOUS 'NUNIT', THAT DATA SET WILL BE READ -C FROM THE BEGINNING, NOT FROM WHERE THE USER LEFT OFF (THIS IS A -C 'SOFTWARE TOOL', NOT AN ENTIRE I/O SYSTEM). -C -C PROGRAM HISTORY LOG: -C 1996-12-13 J. S. WOOLLEN (GSC) -- ORIGINAL AUTHOR - NOTE THIS NEW -C VERSION OF IW3GAD INCORPORATES THE EARLIER VERSION WHICH -C WAS WRITTEN BY J. STACKPOLE AND DEALT ONLY WITH TRUE -C ON29/124 DATA AS INPUT - THIS OPTION IS STILL AVAILABLE -C BUT IS A SMALL PART OF THE NEW ROUTINE WHICH WAS WRITTEN -C FROM SCRATCH TO READ IN BUFR DATA. -C 1997-01-27 D. A. KEYSER -- CHANGES TO MORE CLOSELY DUPLICATE FORMAT -C OBTAINED WHEN READING FROM TRUE ON29/124 DATA SETS. -C 1997-02-04 D. A. KEYSER -- DROPS WITH MISSING STNID GET STNID SET TO -C "DRP88A"; SATWNDS WITH ZERO PRESSURE ARE TOSSED -C 1997-02-12 D. A. KEYSER -- TO GET AROUND THE 3-BIT LIMITATION TO -C THE ON29 PRESSURE Q.M. MNEMONIC "QMPR", AN SDMEDIT/QUIPS -C PURGE OR REJECT FLAG ON PRESSURE IS CHANGED FROM 12 OR 14 -C TO 6 IN ORDER TO FIT INTO 3-BITS, SEE FUNCTION E35O29; -C INTERPRETS SDMEDIT AND QUIPS PURGE/KEEP/CHANGE FLAGS -C PROPERLY FOR ALL DATA TYPES; CAN NOW PROCESS CAT. 6 AND -C CAT. 2/3 TYPE FLIGHT-LEVEL RECCOS (BEFORE SKIPPED THESE); -C TESTS FOR MISSING LAT, LON, OBTIME DECODED FROM BUFR AND -C RETAINS MISSING VALUE ON THESE IN UNPACKED ON29/124 -C FORMAT (BEFORE NO MISSING CHECK, LED TO POSSIBLE NON- -C MISSING BUT INCORRECT VALUES FOR THESE); THE CHECK FOR -C DROPS WITH MISSING STNID REMOVED SINCE DECODER FIXED FOR -C THIS -C 1997-05-01 D. A. KEYSER -- LOOKS FOR DUPLICATE LEVELS WHEN -C PROCESSING ON29 CAT. 2, 3, AND 4 (IN ALL DATA ON LEVEL) -C AND REMOVES DUPLICATE LEVEL; IN PROCESSING ON29 CAT. 3 -C LEVELS, REMOVES ALL LEVELS WHERE WIND IS MISSING; FIXED -C BUG IN AIRCRAFT (AIREP/PIREP/AMDAR) QUALITY MARK -C ASSIGNMENT (WAS NOT ASSIGNING KEEP FLAG TO REPORT IF -C PRESSURE HAD A KEEP Q.M. BUT TEMPERATURE Q.M. WAS -C MISSING) -C 1997-05-30 D. A. KEYSER -- FOR AIRCFT: (ONLY ACARS RIGHT NOW) - -C SECONDS ARE DECODED (IF AVAIL.) AND USED TO OBTAIN -C REPORT TIME; ONLY ASDAR/AMDAR - NEW CAT. 8 CODE FIGS. -C O-PUT 917 (CHAR. 1 & 2 OF ACTUAL STNID), 918 (CHAR. 3 & -C 4 OF ACTUAL STNID), 919 (CHAR. 5 & 6 OF ACTUAL STNID); -C ASDAR/AMDAR AND ACARS - NEW CAT. 8 CODE FIG. O-PUT 920 -C (CHAR. 7 & 8 OF ACTUAL STNID); ONLY ACARS - NEW CAT. 8 -C CODE FIG. O-PUT 921 (REPORT TIME TO NEAREST 1000'TH OF -C AN HOUR); ONLY SOME ACARS - NEW MNEMONIC "IALT" NOW -C EXISTS AND CAN (IF LINE NOT COMMENTED OUT) BE USED TO -C OBTAIN UNPACKED ON29 CAT. 6 -C 1997-07-02 D. A. KEYSER -- REMOVED FILTERING OF AIRCRAFT DATA AS -C FOLLOWS: AIR FRANCE AMDARS NO LONGER FILTERED, AMDAR/ -C ASDAR BELOW 7500 FT. NO LONGER FILTERED, AIREP/PIREP -C BELOW 100 METERS NO LONGER FILTERED, ALL AIRCRAFT WITH -C MISSING WIND BUT VALID TEMPERATURE ARE NO LONGER -C FILTERED; REPROCESSES U.S. SATWND STN. IDS TO CONFORM -C WITH PREVIOUS ON29 APPEARANCE EXCEPT NOW 8-CHAR (TAG -C CHAR. 1 & 6 NOT CHANGED FROM BUFR STN. ID) - NEVER ANY -C DUPL. IDS NOW FOR U.S. SATWNDS DECODED FROM A SINGLE -C BUFR FILE; STREAMLINED/ELIMINATED SOME DO LOOPS TO -C SPEED UP A BIT -C 1997-09-18 D. A. KEYSER -- CORRECTED ERRORS IN REFORMATTING SURFACE -C DATA INTO UNPACKED ON124, SPECIFICALLY-HEADER: INST. TYPE -C (SYNOPTIC FMT FLG, AUTO STN. TYPE, CONVERTED HRLY FLG), -C INDICATORS (PRECIP., WIND SPEED, WX/AUTO STN), CAT51: -C P-TEND, HORIZ. VIZ., PRESENT/PAST WX, CLOUD INFO, MAX/ -C MIN TEMP, CAT52: PRECIP., SNOW DPTH, WAVE INFO, SHIP -C COURSE/SPEED, CAT8: CODE FIGS. 81-85,98; CORRECTED -C PROBLEM WHICH CODED UPPER-AIR MANDATORY LEVEL WINDS -C AS CAT. 3 INSTEAD OF CAT. 1 WHEN MASS DATA (ONLY) WAS -C REPORTED ON SAME MANDATORY LEVEL IN A SEPARATE REPORTED -C LEVEL IN THE RAW BULLETIN -C 1997-10-06 D. A. KEYSER -- UPDATED LOGIC TO READ AND PROCESS NESDIS -C HI-DENSITY SATELLITE WINDS PROPERLY -C 1997-10-30 D. A. KEYSER -- ADDED GROSS CHECK ON U-AIR PRESSURE, ALL -C LEVELS WITH REPORTED PRESSURE .LE. ZERO NOW TOSSED; SFC -C CAT. 52 SEA-SFC TEMPERATURE NOW READ FROM HIERARCHY OF -C SST IN BUFR {1ST CHOICE - HI-RES SST ('SST2'), 2ND -C CHOICE - LO-RES SST ('SST1'), 3RD CHOICE - SEA TEMP -C ('STMP')}, BEFORE ONLY READ 'SST1' -C 1998-01-26 D. A. KEYSER -- CHANGED PQM PROCESSING FOR ADPUPA TYPES -C SUCH THAT SDMEDIT FLAGS ARE NOW HONORED (BEFORE, PQM -C WAS ALWAYS HARDWIRED TO 2 FOR ADPUPA TYPES); BUMPED -C LIMIT FOR NUMBER OF LEVELS THAT CAN BE PROCESSED FROM -C 100 TO 150 AND ADDED DIAGNOSTIC PRINT WHEN THE LIMIT -C IS EXCEEDED -C 1998-05-19 D. A. KEYSER -- Y2K COMPLIANT VERSION OF IW3GAD ROUTINE -C ACCOMPLISHED BY REDEFINING ORIGINAL 32-CHARACTER ON85 -C HEADER LABEL TO BE A 40-CHARACTER LABEL THAT CONTAINS A -C FULL 4-DIGIT YEAR, CAN STILL READ "TRUE" ON29/124 DATA -C SETS PROVIDED THEIR HEADER LABEL IS IN THIS MODIFIED -C FORM -C 1998-07-22 D. A. KEYSER -- MINOR MODIFICATIONS TO ACCOUNT FOR -C CORRECTIONS IN Y2K/F90 BUFRLIB (MAINLY RELATED TO -C BUFRLIB ROUTINE DUMPBF) -C 1998-08-04 D. A. KEYSER -- FIXED A BUG THAT RESULTED IN CODE BEING -C CLOBBERED IN CERTAIN SITUATIONS FOR RECCO REPORTS; MINOR -C MODIFICATIONS TO GIVE SAME ANSWERS ON CRAY AS ON SGI; -C ALLOWED CODE TO READ TRUE ON29/124 FILES WITH NON-Y2K -C COMPLIANT ON85 LABEL (A TEMPORARY MEASURE DURING -C TRANSITION OF MAIN PROGRAMS TO Y2K); ADDED CALL TO "AEA" -C WHICH CONVERTS EBCDIC CHARACTERS TO ASCII FOR INPUT -C TRUE ON29/124 DATA SET PROCESSING OF SGI (WHICH DOES -C NOT SUPPORT "-Cebcdic" IN ASSIGN STATEMENT) -C 1999-02-25 D. A. KEYSER -- ADDED ABILITY TO READ REPROCESSED SSM/I -C BUFR DATA SET (SPSSMI); ADDED ABILITY TO READ MEAN -C SEA-LEVEL PRESSURE BOGUS (PAOBS) DATA SET (SFCBOG) -C 1999-05-14 D. A. KEYSER -- MADE CHANGES NECESSARY TO PORT THIS -C ROUTINE TO THE IBM SP -C 1999-06-18 D. A. KEYSER -- CAN NOW PROCESS WATER VAPOR SATWNDS -C FROM FOREIGN PRODUCERS; STN. ID FOR FOREIGN SATWNDS -C NOW REPROCESSED IN SAME WAY AS FOR NESDIS/GOES SATWNDS, -C CHARACTER 1 OF STN. ID NOW DEFINES EVEN VS. ODD -C SATELLITE WHILE CHARACTER 6 OF STN. ID NOW DEFINES -C IR CLOUD-DRFT VS. VISIBLE CLOUD DRFT VS. WATER VAPOR -C 2002-03-05 D. A. KEYSER -- REMOVED ENTRY "E02O29", NOW PERFORMS -C HEIGHT TO PRESS. CONVERSION DIRECTLY IN CODE FOR CAT. 7; -C TEST FOR MISSING "RPID" CORRECTED FOR ADPUPA DATA (NOW -C CHECKS UFBINT RETURN CODE RATHER THAN VALUE=BMISS); -C ACCOUNTS FOR CHANGES IN INPUT ADPUPA, ADPSFC, AIRCFT -C AND AIRCAR BUFR DUMP FILES AFTER 3/2002: CAT. 7 AND CAT. -C 51 USE MNEMONIC "HBLCS" TO GET HEIGHT OF CLOUD BASE IF -C MNEMONIC "HOCB" NOT AVAILABLE (AND IT WILL NOT BE FOR ALL -C CAT. 7 AND SOME CAT. 51 REPORTS); MNEMONIC "TIWM" -C REPLACES "SUWS" IN HEADER FOR SURFACE DATA; MNEMONIC -C "BORG" REPLACES "ICLI" IN CAT. 8 FOR AIRCRAFT DATA (WILL -C STILL WORK PROPERLY FOR INPUT ADPUPA, ADPSFC, AIRCFT AND -C AIRCAR DUMP FILES PRIOR TO 3/2002) -C 2013-03-20 D. A. KEYSER -- CHANGES TO RUN ON WCOSS: OBTAIN VALUE OF -C BMISS SET IN CALLING PROGRAM VIA CALL TO BUFRLIB ROUTINE -C GETBMISS RATHER THAN HARDWIRING IT TO 10E08 (OR 10E10); -C USE FORMATTED PRINT STATEMENTS WHERE PREVIOUSLY -C UNFORMATTED PRINT WAS USED (WCOSS SPLITS UNFORMATTED -C PRINT AT 80 CHARACTERS) -C -C USAGE: II = IW3UNP29(NUNIT, OBS, IER) -C INPUT ARGUMENT LIST: -C NUNIT - FORTRAN UNIT NUMBER FOR SEQUENTIAL DATA SET CONTAINING -C - PACKED BUFR REPORTS OR PACKED AND BLOCKED OFFICE NOTE -C - 29/124 REPORTS -C -C OUTPUT ARGUMENT LIST: -C OBS - ARRAY CONTAINING ONE REPORT IN UNPACKED OFFICE NOTE -C - 29/124 FORMAT. FORMAT IS MIXED, USER MUST EQUIVALENCE -C - INTEGER AND CHARACTER ARRAYS TO THIS ARRAY (SEE -C - DOCBLOCK FOR W3FI64 IN /nwprod/lib/sorc/w3nco -C - OR WRITEUPS ON W3FI64, ON29, ON124 FOR HELP) -C - THE LENGTH OF THE ARRAY SHOULD BE AT LEAST 1608 -C IER - RETURN FLAG (EQUAL TO FUNCTION VALUE) - SEE REMARKS -C -C INPUT FILES: -C UNIT AA - SEQUENTIAL BUFR OR OFFICE NOTE 29/124 DATA SET ("AA" -C - IS UNIT NUMBER SPECIFIED BY INPUT ARGUMENT "NUNIT") -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C SUBPROGRAMS CALLED: -C UNIQUE: xxxxxx -C LIBRARY: -C UTILITY - xxxxxx -C W3NCO - xxxxxx -C W3EMC - xxxxxx -C BUFRLIB - xxxxxx -C -C REMARKS: -C IF INPUT DATA SET IS ON29/124, IT SHOULD BE ASSIGNED IN THIS WAY: -C Cray: -C assign -a ADPUPA -Fcos -Cebcdic fort.XX -C SGI: -C assign -a ADPUPA -Fcos fort.XX -C (Note: -Cebcdic is not possible on SGI, so call to W3NCO -C routine "AEA" takes care of the conversion as each -C ON29 record is read in) -C IF INPUT DATA SET IS BUFR, IT SHOULD BE ASSIGNED IN THIS WAY: -C Cray: -C assign -a ADPUPA fort.XX -C SGI: -C assign -a ADPUPA -F cos fort.XX -C -C NOTE: FOR INPUT ON29/124 DATA SETS, A CONTINGENCY HAS BEEN BUILT -C INTO THIS SUBROUTINE TO PERFORM THE CONVERSION FROM EBCDIC TO -C ASCII IN THE EVENT THE assign DOES NOT PERFORM THE CONVERSION -C -C THE RETURN FLAGS IN IER (AND FUNCTION IW3UNP29 ITSELF) ARE: -C = 0 OBSERVATION READ AND UNPACKED INTO LOCATION 'OBS'. -C SEE WRITEUP OF W3FI64 FOR CONTENTS. (ALL CHARACTER -C WORDS ARE LEFT-JUSTIFIED.) NEXT CALL TO IW3UNP29 -C WILL RETURN NEXT OBSERVATION IN DATA SET. -C = 1 A 40 BYTE HEADER IN THE FORMAT DESCRIBED HERE -C (Y2K COMPLIANT PSEUDO-OFFICE NOTE 85) IS RETURNED -C IN THE FIRST 10 WORDS OF 'OBS' ON a 4-BYTE MACHINE -C (IBM) AND IN THE FIRST 5 WORDS OF 'OBS' ON AN -C 8-BYTE MACHINE (CRAY). NEXT CALL TO -C IW3UNP29 WILL RETURN FIRST OBS. IN THIS DATA SET. -C (NOTE: IF INPUT DATA SET IS A TRUE ON29/124 FILE -C WITH THE Y2K COMPLIANT PSEUDO-ON85 HEADER RECORD, -C THEN THE PSEUDO-ON85 HEADER RECORD IS ACTUALLY -C READ IN AND RETURNED; IF INPUT DATA SET IS A TRUE -C ON29/124 FILE WITH A NON-Y2K COMPLIANT ON85 HEADER -C RECORD, THEN A Y2K COMPLIANT PSEUDO-ON85 HEADER -C RECORD IS CONSTRUCTED FROM IT USING THE "WINDOWING" -C TECHNIQUE TO OBTAIN A 4-DIGIT YEAR FROM A 2-DIGIT -C YEAR.) -C FORMAT FOR Y2K COMPLIANT PSEUDO-ON85 HEADER RECORD -C RETURNED (40 BYTES IN CHARACTER): -C BYTES 1- 8 -- DATA SET NAME (AS DEFINED IN ON85 -C EXCEPT UP TO EIGHT ASCII CHAR., -C LEFT JUSTIFIED WITH BLANK FILL) -C BYTES 9-10 -- SET TYPE (AS DEFINED IN ON85) -C BYTES 11-20 -- CENTER (ANALYSIS) DATE FOR DATA -C SET (TEN ASCII CHARACTERS IN FORM -C "YYYYMMDDHH") -C BYTES 21-24 -- SET INITIALIZE (DUMP) TIME, AS -C DEDINED IN ON85) -C BYTES 25-34 -- ALWAYS "WASHINGTON" (AS IN ON85) -C BYTES 35-36 -- SOURCE MACHINE (AS DEFINED IN ON85) -C BYTES 37-40 -- BLANK FILL CHARACTERS -C -C = 2 END-OF-FILE (NEVER AN EMPTY OR NULL FILE): -C INPUT ON29/124 DATA SET: THE "ENDOF FILE" RECORD IS -C ENCOUNTERED - NO USEFUL INFORMATION IN 'OBS' ARRAY. -C NEXT CALL TO IW3UNP29 WILL RETURN PHYSICAL END OF -C FILE FOR DATA SET IN 'NUNIT' (SEE IER=3 BELOW). -C INPUT BUFR DATA SET: THE PHYSICAL END OF FILE IS -C ENCOUNTERED. -C = 3 END-OF-FILE: -C PHYSICAL END OF FILE ENCOUNTERED ON DATA SET - -C THIS CAN ONLY HAPPEN FOR AN EMPTY (NULL) DATA SET -C OR FOR A TRUE ON29/124 DATA SET. THERE ARE NO -C MORE REPORTS (OR NEVER WERE ANY IF NULL) ASSOCIATED -C WITH DATA SET IN THIS UNIT NUMBER - NO USEFUL -C INFORMATION IN 'OBS' ARRAY. EITHER ALL DONE (IF -C NO MORE UNIT NUMBERS ARE TO BE READ IN), OR RESET -C 'NUNIT' TO POINT TO A NEW DATA SET (IN WHICH CASE -C NEXT CALL TO IW3UNP29 SHOULD RETURN WITH IER=1). -C = 4 ONLY VALID FOR INPUT ON29/124 DATA SET - I/O ERROR -C READING THE NEXT RECORD OF REPORTS - NO USEFUL -C INFORMATION IN 'OBS' ARRAY. CALLING PROGRAM CAN -C CHOOSE TO STOP OR AGAIN CALL IW3UNP29 WHICH WILL -C ATTEMPT TO UNPACK THE FIRST OBSERVATION IN THE NEXT -C RECORD OF REPORTS. -C = 999 APPLIES ONLY TO NON-EMPTY DATA SETS: -C INPUT ON29/124 DATA SET: FIRST CHOICE Y2K COMPLIANT -C PSEUDO-ON85 FILE HEADER LABEL NOT ENCOUNTERED WHERE -C EXPECTED, AND SECOND CHOICE NON-Y2K COMPLIANT ON85 -C FILE HEADER LABEL ALSO NOT ENCOUNTERED. -C INPUT BUFR DATA SET: EITHER HEADER LABEL IN -C FORMAT OF PSEUDO-ON85 COULD NOT BE RETURNED, OR AN -C ABNORMAL ERROR OCCURRED IN THE ATTEMPT TO DECODE AN -C OBSERVATION. FOR EITHER INPUT DATA SET TYPE, NO -C USEFUL INFORMATION IN 'OBS' ARRAY. CALLING PROGRAM -C CAN CHOOSE TO STOP WITH NON-ZERO CONDITION CODE OR -C RESET 'NUNIT' TO POINT TO A NEW DATA SET (IN WHICH -C CASE NEXT CALL TO IW3UNP29 SHOULD RETURN WITH -C IER=1). -C INPUT DATA SET NEITHER ON29/124 NOR BUFR: SPEAKS FOR -C ITSELF. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: NCEP WCOSS -C -C$$$ - FUNCTION IW3UNP29(LUNIT,OBS,IER) - - COMMON/IO29AA/JWFILE(100),LASTF - COMMON/IO29BB/KNDX,KSKACF(8),KSKUPA,KSKSFC,KSKSAT,KSKSMI - COMMON/IO29CC/SUBSET,IDAT10 - COMMON/IO29DD/HDR(12),RCATS(50,150,11),IKAT(11),MCAT(11),NCAT(11) - COMMON/IO29EE/ROBS(255,11) - COMMON/IO29FF/QMS(255,9) - COMMON/IO29GG/SFO(34) - COMMON/IO29HH/SFQ(5) - COMMON/IO29II/PWMIN - COMMON/IO29JJ/ISET,MANLIN(1001) - COMMON/IO29KK/KOUNT(499,18) - COMMON/IO29LL/BMISS - - DIMENSION OBS(*) - REAL(8) BMISS,GETBMISS - - SAVE - - DATA ITIMES/0/ - - IF(ITIMES.EQ.0) THEN - -C THE FIRST TIME IN, INITIALIZE SOME DATA -C (NOTE: FORTRAN 77/90 STANDARD DOES NOT ALLOW COMMON BLOCK VARIABLES -C TO BE INITIALIZED VIA DATA STATEMENTS, AND, FOR SOME REASON, -C THE BLOCK DATA DOES NOT INITIALIZE DATA IN THE W3NCO LIBRARY -C AVOID BLOCK DATA IN W3NCO/W3EMC) -C -------------------------------------------------------------------- - - ITIMES = 1 - JWFILE = 0 - LASTF = 0 - KNDX = 0 - KSKACF = 0 - KSKUPA = 0 - KSKSFC = 0 - KSKSAT = 0 - KSKSMI = 0 - KOUNT = 0 - IKAT(1) = 1 - IKAT(2) = 2 - IKAT(3) = 3 - IKAT(4) = 4 - IKAT(5) = 5 - IKAT(6) = 6 - IKAT(7) = 7 - IKAT(8) = 8 - IKAT(9) = 51 - IKAT(10) = 52 - IKAT(11) = 9 - MCAT(1) = 6 - MCAT(2) = 4 - MCAT(3) = 4 - MCAT(4) = 4 - MCAT(5) = 6 - MCAT(6) = 6 - MCAT(7) = 3 - MCAT(8) = 3 - MCAT(9) = 21 - MCAT(10) = 15 - MCAT(11) = 3 - ISET = 0 - END IF - -C UNIT NUMBER OUT OF RANGE RETURNS A 999 -C -------------------------------------- - - IF(LUNIT.LT.1 .OR. LUNIT.GT.100) THEN - PRINT'(" ##IW3UNP29 - UNIT NUMBER ",I0," OUT OF RANGE -- ", - $ "IER = 999")', LUNIT - GO TO 9999 - END IF - IF(LASTF.NE.LUNIT .AND. LASTF.GT.0) THEN - CALL CLOSBF(LASTF) - JWFILE(LASTF) = 0 - END IF - LASTF = LUNIT - -C THE JWFILE INDICATOR: =0 IF UNOPENED; =1 IF ON29; =2 IF BUFR -C ------------------------------------------------------------ - - IF(JWFILE(LUNIT).EQ.0) THEN - PRINT'(" ===> IW3UNP29 - WCOSS VERSION: 03-20-2013")' - - BMISS = GETBMISS() - print'(1X)' - print'(" BUFRLIB value for missing passed into IW3UNP29 is: ", - $ G0)', bmiss - print'(1X)' - - IF(I03O29(LUNIT,OBS,IER).EQ.1) THEN - PRINT'(" IW3UNP29 - OPENED A TRUE OFFICE NOTE 29 FILE IN ", - $ "UNIT ",I0)', LUNIT - JWFILE(LUNIT) = 1 - IER = 1 - IW3UNP29 = 1 - ELSEIF(I03O29(LUNIT,OBS,IER).EQ.3) THEN - PRINT 107, LUNIT - 107 FORMAT(/,' ##IW3UNP29 - FILE IN UNIT',I3,' IS EMPTY OR NULL -- ', - $ 'IER = 3'/) - IER = 3 - IW3UNP29 = 3 - ELSEIF(I02O29(LUNIT,OBS,IER).EQ.1) THEN - PRINT'(" IW3UNP29 - OPENED A BUFR FILE IN UNIT ",I0)', LUNIT - - JWFILE(LUNIT) = 2 - KNDX = 0 - KSKACF = 0 - KSKUPA = 0 - KSKSFC = 0 - KSKSAT = 0 - KSKSMI = 0 - IER = 1 - IW3UNP29 = 1 - ELSEIF(I03O29(LUNIT,OBS,IER).EQ.999) THEN - PRINT'(" IW3UNP29 - OPENED A TRUE OFFICE NOTE 29 FILE IN ", - $ "UNIT ",I0)', LUNIT - PRINT 88 - 88 FORMAT(/' ##IW3UNP29/I03O29 - NEITHER EXPECTED Y2K COMPLIANT ', - $ 'PSEUDO-ON85 LABEL NOR SECOND CHOICE NON-Y2K COMPLIANT ON85 ', - $ 'LABEL FOUND IN'/21X,'FIRST RECORD OF FILE -- IER = 999'/) - GO TO 9999 - ELSE - PRINT 108, LUNIT - 108 FORMAT(/,' ##IW3UNP29 - FILE IN UNIT',I3,' IS NEITHER BUFR NOR ', - $ 'TRUE OFFICE NOTE 29 -- IER = 999'/) - GO TO 9999 - END IF - ELSEIF(JWFILE(LUNIT).EQ.1) THEN - IF(I03O29(LUNIT,OBS,IER).NE.0) JWFILE(LUNIT) = 0 - IF(IER.GT.0) CLOSE (LUNIT) - IW3UNP29 = IER - ELSEIF(JWFILE(LUNIT).EQ.2) THEN - IF(I02O29(LUNIT,OBS,IER).NE.0) JWFILE(LUNIT) = 0 - IF(IER.GT.0) CALL CLOSBF(LUNIT) - IF(IER.EQ.2.OR.IER.EQ.3) THEN - IF(KSKACF(1).GT.0) PRINT'(" IW3UNP29 - NO. OF AIRCFT/", - $ "AIRCAR REPORTS TOSSED DUE TO ZERO CAT. 6 LVLS = ",I0)', - $ KSKACF(1) - IF(KSKACF(2).GT.0) PRINT'(" IW3UNP29 - NO. OF AIRCFT ", - $ "REPORTS TOSSED DUE TO BEING ""LFPW"" AMDAR = ",I0)', - $ KSKACF(2) - IF(KSKACF(8).GT.0) PRINT'(" IW3UNP29 - NO. OF AIRCFT ", - $ "REPORTS TOSSED DUE TO BEING ""PHWR"" AIREP = ",I0)', - $ KSKACF(8) - IF(KSKACF(3).GT.0) PRINT'(" IW3UNP29 - NO. OF AIRCFT ", - $ "REPORTS TOSSED DUE TO BEING CARSWELL AMDAR = ",I0)', - $ KSKACF(3) - IF(KSKACF(4).GT.0) PRINT'(" IW3UNP29 - NO. OF AIRCFT ", - $ "REPORTS TOSSED DUE TO BEING CARSWELL ACARS = ",I0)', - $ KSKACF(4) - IF(KSKACF(5).GT.0) PRINT'(" IW3UNP29 - NO. OF AIRCFT/", - $ "AIRCAR REPORTS TOSSED DUE TO HAVING MISSING WIND = ",I0)', - $ KSKACF(5) - IF(KSKACF(6).GT.0) PRINT'(" IW3UNP29 - NO. OF AIRCFT ", - $ "REPORTS TOSSED DUE TO BEING AMDAR < 2286 M = ",I0)', - $ KSKACF(6) - IF(KSKACF(7).GT.0) PRINT'(" IW3UNP29 - NO. OF AIRCFT ", - $ "REPORTS TOSSED DUE TO BEING AIREP < 100 M = ",I0)', - $ KSKACF(7) - IF(KSKACF(1)+KSKACF(2)+KSKACF(3)+KSKACF(4)+KSKACF(5)+ - $ KSKACF(6)+KSKACF(7)+KSKACF(8).GT.0) - $ PRINT'(" IW3UNP29 - TOTAL NO. OF AIRCFT/AIRCAR REPORTS ", - $ "TOSSED = ",I0)', - $ KSKACF(1)+KSKACF(2)+KSKACF(3)+KSKACF(4)+ - $ KSKACF(5)+KSKACF(6)+KSKACF(7)+KSKACF(8) - IF(KSKUPA.GT.0) PRINT'(" IW3UNP29 - TOTAL NO. OF ADPUPA ", - $ "REPORTS TOSSED = ",I0)', KSKUPA - IF(KSKSFC.GT.0) PRINT'(" IW3UNP29 - TOTAL NO. OF ADPSFC/", - $ "SFCSHP/SFCBOG REPORTS TOSSED = ",I0)', KSKSFC - IF(KSKSAT.GT.0) PRINT'(" IW3UNP29 - TOTAL NO. OF SATWND ", - $ "REPORTS TOSSED = ",I0)', KSKSAT - IF(KSKSMI.GT.0) PRINT'(" IW3UNP29 - TOTAL NO. OF SPSSMI ", - $ "REPORTS TOSSED = ",I0)', KSKSMI - KNDX = 0 - KSKACF = 0 - KSKUPA = 0 - KSKSFC = 0 - KSKSAT = 0 - KSKSMI = 0 - END IF - IW3UNP29 = IER - END IF - - RETURN - - 9999 CONTINUE - IER = 999 - IW3UNP29 = 999 - RETURN - - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** -C----------------------------------------------------------------------- -C I01O29 RETURNS LOOK ALIKE Y2K COMPL. PSEUDO-ON85 HDR FROM A DATA FILE -C----------------------------------------------------------------------- - FUNCTION I01O29(LUNIT,HDR,IER) -C ---> formerly FUNCTION IW3HDR - - COMMON/IO29AA/JWFILE(100),LASTF - - DIMENSION HDR(*) - - SAVE - -C UNIT NUMBER OUT OF RANGE RETURNS A 999 -C -------------------------------------- - - IF(LUNIT.LT.1 .OR. LUNIT.GT.100) THEN - PRINT'(" ##IW3UNP29/I01O29 - UNIT NUMBER ",I0," OUT OF RANGE ", - $ "-- IER = 999")', LUNIT - GO TO 9999 - END IF - -C THE JWFILE INDICATOR: =0 IF UNOPENED; =1 IF ON29; =2 IF BUFR -C ------------------------------------------------------------ - - IF(JWFILE(LUNIT).EQ.0) THEN - IF(I03O29(LUNIT,HDR,IER).EQ.1) THEN - I01O29 = I03O29(0,HDR,IER) - I01O29 = 1 - RETURN - ELSEIF(I02O29(LUNIT,HDR,IER).EQ.1) THEN - CALL CLOSBF(LUNIT) - I01O29 = 1 - RETURN - ELSE - -C CAN'T READ FILE HEADER RETURNS A 999 -C ------------------------------------ - - PRINT'(" ##IW3UNP29/I01O29 - CAN""T READ FILE HEADER -- ", - $ "IER = 999")' - GO TO 9999 - END IF - ELSE - -C FILE ALREADY OPEN RETURNS A 999 -C ------------------------------- - - PRINT'(" ##IW3UNP29/I01O29 - FILE ALREADY OPEN -- IER = 999")' - GO TO 9999 - END IF - - RETURN - - 9999 CONTINUE - IER = 999 - I01O29 = 999 - RETURN - - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION I02O29(LUNIT,OBS,IER) -C ---> formerly FUNCTION JW3O29 - - COMMON/IO29CC/SUBSET,IDAT10 - - CHARACTER*40 ON85 - CHARACTER*10 CDATE - CHARACTER*8 SUBSET,CBUFR - CHARACTER*6 C01O29 - CHARACTER*4 CDUMP - DIMENSION OBS(1608),RON85(16),JDATE(5),JDUMP(5) - EQUIVALENCE (RON85(1),ON85) - - SAVE - - DATA ON85/' '/ - - JDATE = -1 - JDUMP = -1 - -C IF FILE IS CLOSED TRY TO OPEN IT AND RETURN A Y2K COMPLIANT -C PSEUDO-ON85 LABEL -C ----------------------------------------------------------- - - CALL STATUS(LUNIT,LUN,IL,IM) - - IF(IL.EQ.0) THEN - IRET = -1 - I02O29 = 2 - REWIND LUNIT - READ(LUNIT,END=10,ERR=10,FMT='(A8)') CBUFR - IF(CBUFR(1:4).EQ.'BUFR') THEN - PRINT'(" IW3UNP29/I02O29 - INPUT FILE ON UNIT ",I0, " IS", - $ " UNBLOCKED NCEP BUFR"/)', LUNIT - ELSE IF(CBUFR(5:8).EQ.'BUFR') THEN - PRINT'(" IW3UNP29/I02O29 - INPUT FILE ON UNIT ",I0, " IS", - $ " BLOCKED NCEP BUFR"/)', LUNIT - ELSE - REWIND LUNIT - GO TO 10 - END IF - call datelen(10) - CALL DUMPBF(LUNIT,JDATE,JDUMP) -cppppp - print'(" CENTER DATE (JDATE) = ",I4,4I3.2/" DUMP DATE (JDUMP)", - $ " (year not used anywhere) = "I4,4I3.2)',jdate,jdump -cppppp - IF(JDATE(1).GT.999) THEN - WRITE(CDATE,'(I4.4,3I2.2)') (JDATE(I),I=1,4) - ELSE IF(JDATE(1).GT.0) THEN - -C If 2-digit year returned in JDATE(1), must use "windowing" technique -C 2 create a 4-digit year - - PRINT'(" ##IW3UNP29/I02O29 - 2-DIGIT YEAR IN JDATE(1) ", - $ "RETURNED FROM DUMPBF (JDATE IS: ",I4.4,3I2.2,") - USE ", - $ "WINDOWING TECHNIQUE TO OBTAIN 4-DIGIT YEAR")', JDATE - IF(JDATE(1).GT.20) THEN - WRITE(CDATE,'("19",4I2.2)') (JDATE(I),I=1,4) - ELSE - WRITE(CDATE,'("20",4I2.2)') (JDATE(I),I=1,4) - ENDIF - PRINT'(" ##IW3UNP29/I02O29 - CORRECTED JDATE(1) WITH ", - $ "4-DIGIT YEAR, JDATE NOW IS: ",I4.4,3I2.2)', JDATE - ELSE - GO TO 10 - ENDIF - - CALL OPENBF(LUNIT,'IN',LUNIT) - -C This next call, I believe, is needed only because SUBSET is not -C returned in DUMPBF ... - call readmg(lunit,subset,idat10,iret) - - WRITE(CDUMP,'(2I2.2)') JDUMP(4),100*JDUMP(5)/60 - IF(JDUMP(1).LT.0) CDUMP = '9999' - ON85=C01O29(SUBSET)//' C2'//CDATE//CDUMP//'WASHINGTONCR ' - OBS(1:16) = RON85 - I02O29 = 1 - 10 CONTINUE - IER = I02O29 - RETURN - END IF - -C IF THE FILE IS ALREADY OPENED FOR INPUT TRY TO READ THE NEXT SUBSET -C ------------------------------------------------------------------- - - IF(IL.LT.0) THEN - 7822 CONTINUE - CALL READNS(LUNIT,SUBSET,IDAT10,IRET) - IF(IRET.EQ.0) I02O29 = R01O29(SUBSET,LUNIT,OBS) - IF(IRET.NE.0) I02O29 = 2 - IF(I02O29.EQ.-9999) GO TO 7822 - IER = I02O29 - RETURN - END IF - -C FILE MUST BE OPEN FOR INPUT! -C ---------------------------- - - PRINT'(" ##IW3UNP29/I02O29 - FILE ON UNIT ",I0," IS OPENED FOR ", - $ "OUTPUT -- IER = 999")', LUNIT - I02O29 = 999 - IER = 999 - RETURN - - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: I03O29 -C PRGMMR: KEYSER ORG: NP22 DATE: 2013-03-20 -C -C ABSTRACT: READS A TRUE (SEE *) ON29/124 DATA SET AND UNPACKS ONE -C REPORT INTO THE UNPACKED OFFICE NOTE 29/124 FORMAT. THE INPUT AND -C OUTPUT ARGUMENTS HERE HAVE THE SAME MEANING AS FOR IW3UNP29. -C REPEATED CALLS OF FUNCTION WILL RETURN A SEQUENCE OF UNPACKED -C ON29/124 REPORTS. * - UNLIKE ORIGINAL "TRUE" ON29/124 DATA SETS, -C THE "EXPECTED" FILE HEADER LABEL IS A Y2K COMPLIANT 40-BYTE -C PSEUDO-ON85 VERSION - IF THIS IS NOT ENCOUNTERED THIS CODE, AS A -C TEMPORARY MEASURE DURING THE Y2K TRANSITION PERIOD, WILL LOOK FOR -C THE ORIGINAL NON-Y2K COMPLIANT 32-BYTE ON85 HEADER LABEL AND USE -C THE "WINDOWING" TECHNIQUE TO CONVERT THE 2-DIGIT YEAR TO A 4-DIGIT -C YEAR IN PREPARATION FOR RETURNING A 40-BYTE PSEUDO-ON85 LABEL IN -C THE FIRST C CALL. (SEE IW3UNP29 DOCBLOCK FOR FORMAT OF 40-BYTE -C PSEUDO-ON85 HEADER LABEL.) -C -C PROGRAM HISTORY LOG: -C 1980-12-01 J.STACKPOLE -- ORIGINAL W3LIB ROUTINE IW3GAD -C 1984-06-26 R.E.JONES -- CONVERT TO VS FORTRAN -C 1991-07-23 D.A.KEYSER -- NOW CALLS W3FI64 (F77); INTERNAL READ ERROR -C NO LONGER CAUSES CALLING PROGRAM TO FAIL BUT WILL MOVE -C TO NEXT RECORD IF CAN'T RECOVER TO NEXT REPORT -C 1993-10-07 D.A.KEYSER -- ADAPTED FOR USE ON CRAY (ADDED SAVE -C STATEMENT, REMOVED IBM-SPECIFIC CODE, ETC.) -C 1993-10-15 R.E.JONES -- ADDED CODE SO IF FILE IS EBCDIC IT CONVERTS -C IT TO ASCII -C 1996-10-04 J.S.WOOLLEN -- CHANGED NAME TO I03GAD AND INCORPORATED -C INTO NEW W3LIB ROUTINE IW3GAD -C 2013-03-20 D. A. KEYSER -- CHANGES TO RUN ON WCOSS -C -C USAGE: II = I03O29(NUNIT, OBS, IER) -C INPUT ARGUMENT LIST: -C NUNIT - FORTRAN UNIT NUMBER FOR SEQUENTIAL DATA SET CONTAINING -C - PACKED AND BLOCKED OFFICE NOTE 29/124 REPORTS -C -C OUTPUT ARGUMENT LIST: -C OBS - ARRAY CONTAINING ONE REPORT IN UNPACKED OFFICE NOTE -C - 29/124 FORMAT. FORMAT IS MIXED, USER MUST EQUIVALENCE -C - INTEGER AND CHARACTER ARRAYS TO THIS ARRAY (SEE -C - DOCBLOCK FOR W3FI64 IN /nwprod/lib/sorc/w3nco -C - OR WRITEUPS ON W3FI64, ON29, ON124 FOR HELP) -C - THE LENGTH OF THE ARRAY SHOULD BE AT LEAST 1608 -C IER - RETURN FLAG (EQUAL TO FUNCTION VALUE) - SEE REMARKS -C - IN IW3UNP29 DOCBLOCK -C -C INPUT FILES: -C UNIT AA - SEQUENTIAL OFFICE NOTE 29/124 DATA SET ("AA" IS UNIT -C - NUMBER SPECIFIED BY INPUT ARGUMENT "NUNIT") -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBPROGRAM IW3UNP29. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: NCEP WCOSS -C -C$$$ - FUNCTION I03O29(NUNIT, OBS, IER) -C ---> formerly FUNCTION KW3O29 - - CHARACTER*1 CBUFF(6432),CON85L(32) - CHARACTER*2 CBF910 - CHARACTER*4 CYR4D - CHARACTER*8 CBUFR - INTEGER IBUFF(5),OBS(*) - - EQUIVALENCE (IBUFF,CBUFF) - - SAVE - - DATA IOLDUN/0/ - -C TEST FOR NEW (OR PREVIOUSLY USED) NUNIT AND ADJUST 'NEXT' -C (THIS ALLOWS USER TO SWITCH TO NEW NUNIT PRIOR TO READING TO -C THE 'END OF FILE' ON AN OLD UNIT. ANY SWITCH TO A NEW UNIT WILL -C START THE READ AT THE BEGINNING) -C ---------------------------------------------------------------- - - if(nunit.eq.0) then - if(ioldun.gt.0) rewind ioldun - I03O29 = 0 - ioldun = 0 - return - end if - - IF(NUNIT.NE.IOLDUN) THEN - -C THIS IS A NEW UNIT NUMBER, SET 'NEXT' TO 0 AND REWIND THIS UNIT -C --------------------------------------------------------------- - -CDAKCDAK PRINT 87, NUNIT NOW REDUNDANT TO PRINT THIS - 87 FORMAT(//' IW3UNP29/I03O29 - PREPARING TO READ ON29 DATA SET IN ', - $ 'UNIT ',I3/) - IOLDUN = NUNIT - NEXT = 0 - NFILE = 0 - REWIND NUNIT - ISWT = 0 - END IF - - 10 CONTINUE - - IF(NEXT.NE.0) GO TO 70 - -C COME HERE TO READ IN A NEW RECORD (EITHER REPORTS, Y2K COMPLIANT 40- -C BYTE PSEUDO-ON85 LBL, NON-Y2K 32-BYTE COMPLIANT ON85 LBL, OR E-O-F) -C -------------------------------------------------------------------- - - READ(NUNIT,END=9997,ERR=9998,FMT='(A8)') CBUFR - IF(CBUFR(1:4).EQ.'BUFR' .OR. CBUFR(5:8).EQ.'BUFR') THEN - -C INPUT DATASET IS BUFR - EXIT IMMEDIATELY -C ---------------------------------------- - - IOLDUN = 0 - NEXT = 0 - IER = 999 - GO TO 90 - END IF - - REWIND NUNIT - - READ(NUNIT,ERR=9998,END=9997,FMT='(6432A1)') CBUFF - -C IF ISWT=1, CHARACTER DATA IN RECORD ARE EBCDIC - CONVERT TO ASCII -C ----------------------------------------------------------------- - - IF(ISWT.EQ.1) CALL AEA(CBUFF,CBUFF,6432) - - IF(NFILE.EQ.0) THEN - -C TEST FOR EXPECTED HEADER LABEL -C ------------------------------ - - NFILE = 1 - - IF(CBUFF(25)//CBUFF(26)//CBUFF(27)//CBUFF(28).EQ.'WASH') THEN - ELSEIF(CBUFF(21)//CBUFF(22)//CBUFF(23)//CBUFF(24).EQ.'WASH')THEN - ELSE - -C QUICK CHECK SHOWS SOMETHING OTHER THAN EITHER Y2K COMPLIANT PSEUDO- -C ON85 LBL OR NON-Y2K COMPLIANT ON85 LBL FOUND -- COULD MEAN CHARACTER -C DATA ARE IN EBCDIC, SO SEE IF CONVERSION TO ASCII RECTIFIES THIS -C --------------------------------------------------------------------- - - PRINT 78 - 78 FORMAT(/' ##IW3UNP29 - NEITHER EXPECTED Y2K COMPLIANT PSEUDO-', - $ 'ON85 LABEL NOR SECOND CHOICE NON-Y2K COMPLIANT ON85 LABEL ', - $ 'FOUND IN'/14X,'FIRST RECORD OF FILE -- TRY EBCDIC TO ASCII ', - $ 'CONVERSION'/) - CALL AEA(CBUFF,CBUFF,6432) - ISWT = 1 - END IF - - IF(CBUFF(25)//CBUFF(26)//CBUFF(27)//CBUFF(28).EQ.'WASH') THEN - -C THIS IS Y2K COMPLIANT 40-BYTE PSEUDO-ON85 LBL; RESET 'NEXT', SET -C 'IER', FILL 'OBS(1)-(4)', AND QUIT -C --------------------------------------------------------------- - NEXT = 0 - IER = 1 - OBS(1:5) = IBUFF(1:5) - GO TO 90 - ELSE IF(CBUFF(21)//CBUFF(22)//CBUFF(23)//CBUFF(24).EQ.'WASH') - $ THEN - -C THIS IS NON-Y2K COMPLIANT 32-BYTE ON85 LBL; RESET 'NEXT', SET -C 'IER', USE "WINDOWING" TECHNIQUE TO CONTRUCT 4-DIGIT YEAR, -C CONSTRUCT A 40-BYTE PSEUDO-ON85 LABE, FILL 'OBS(1)-(4)', AND QUIT -C ------------------------------------------------------------------ - PRINT'(" ==> THIS IS A TRUE OFFICE NOTE 29 FILE!! <==")' - PRINT 88 - 88 FORMAT(/' ##IW3UNP29/I03O29 - WARNING: ORIGINAL NON-Y2K ', - $ 'COMPLIANT ON85 LABEL FOUND IN FIRST RECORD OF FILE INSTEAD OF ', - $ 'EXPECTED'/30X,'Y2K COMPLIANT PSEUDO-ON85 LABEL -- THIS ', - $ 'ROUTINE IS FORCED TO USE "WINDOWING" TECHNIQUE TO CONTRUCT'/30X, - $'A Y2K COMPLIANT PSEUDO-ON85 LABEL TO RETURN TO CALLING PROGRAM'/) - - NEXT = 0 - IER = 1 - - CBF910 = CBUFF(9)//CBUFF(10) - READ(CBF910,'(I2)') IYR2D - PRINT'(" ##IW3UNP29/I03O29 - 2-DIGIT YEAR FOUND IN ON85 ", - $ "LBL (",A,") IS: ",I0/19X," USE WINDOWING TECHNIQUE TO ", - $ "OBTAIN 4-DIGIT YEAR")', CBUFF(1:32),IYR2D - IF(IYR2D.GT.20) THEN - IYR4D = 1900 + IYR2D - ELSE - IYR4D = 2000 + IYR2D - ENDIF - PRINT'(" ##IW3UNP29/I03O29 - 4-DIGIT YEAR OBTAINED VIA ", - $ "WINDOWING TECHNIQUE IS: ",I0/)', IYR4D - CON85L = CBUFF(1:32) - CBUFF(7:40) = ' ' - CBUFF(9:10) = CON85L(7:8) - WRITE(CYR4D,'(I4.4)') IYR4D - DO I=1,4 - CBUFF(10+I) = CYR4D(I:I) - ENDDO - CBUFF(15:36) = CON85L(11:32) - OBS(1:5) = IBUFF(1:5) - GO TO 90 - ELSE - -C SOMETHING OTHER THAN EITHER Y2K COMPLIANT PSEUDO-ON85 LBL OR -C NON-Y2K COMPLIANT ON85 LBL FOUND; RESET 'NEXT', SET 'IER' AND QUIT -C ------------------------------------------------------------------ -CDAKCDAK PRINT 88 CAN'T PRINT THIS ANYMORE -CDA88 FORMAT(/' ##IW3UNP29/I03O29 - EXPECTED ON85 LABEL NOT FOUND IN ', -CDAK $ 'FIRST RECORD OF NEW LOGICAL FILE -- IER = 999'/) - IOLDUN = 0 - NEXT = 0 - IER = 999 - GO TO 90 - END IF - - END IF - - IF(CBUFF(1)//CBUFF(2)//CBUFF(3)//CBUFF(4).EQ.'ENDO') THEN - -C LOGICAL "ENDOF FILE" READ; RESET NEXT, SET IER, AND QUIT -C -------------------------------------------------------- - - NEXT = 0 - IER = 2 - NFILE = 0 - GO TO 90 - END IF - GO TO 70 - - 9997 CONTINUE - -C PHYSICAL END OF FILE; RESET 'NEXT', SET 'IER' AND QUIT -C ------------------------------------------------------ - - NEXT = 0 - IER = 3 - GO TO 90 - - 9998 CONTINUE - -C I/O ERROR; RESET 'NEXT', SET 'IER' AND QUIT -C ------------------------------------------- - -cppppp - print'(" ##IW3UNP29/I03O29 - ERROR READING DATA RECORD")' -cppppp - NEXT = 0 - IER = 4 - GO TO 90 - - 70 CONTINUE - -C WORKING WITHIN ACTUAL DATA REC. READ, CALL W3FI64 TO READ IN NEXT RPT -C --------------------------------------------------------------------- - - CALL W3FI64(CBUFF,OBS,NEXT) - - IF(NEXT.GE.0) THEN - -C REPORT SUCCESSFULLY RETURNED IN ARRAY 'OBS' -C ------------------------------------------- - - IER = 0 - - ELSE - -C HIT END-OF-RECORD, OR INTERNAL READ ERROR ENCOUNTERED & CAN'T RECOVER -C -- READ IN NEXT RECORD OF REPORTS -C --------------------------------------------------------------------- - - NEXT = 0 - GO TO 10 - END IF - - 90 CONTINUE - - I03O29 = IER - - RETURN - - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION C01O29(SUBSET) -C ---> formerly FUNCTION ADP - - CHARACTER*(*) SUBSET - CHARACTER*6 C01O29 - - SAVE - - C01O29 = 'NONE' - - IF(SUBSET(1:5).EQ.'NC000') C01O29 = 'ADPSFC' - IF(SUBSET(1:5).EQ.'NC001') THEN - IF(SUBSET(6:8).NE.'006') THEN - C01O29 = 'SFCSHP' - ELSE - C01O29 = 'SFCBOG' - END IF - END IF - IF(SUBSET(1:5).EQ.'NC002') C01O29 = 'ADPUPA' - IF(SUBSET(1:5).EQ.'NC004') C01O29 = 'AIRCFT' - IF(SUBSET(1:5).EQ.'NC005') C01O29 = 'SATWND' - IF(SUBSET(1:5).EQ.'NC012') C01O29 = 'SPSSMI' - - IF(SUBSET .EQ. 'NC003101') C01O29 = 'SATEMP' - IF(SUBSET .EQ. 'NC004004') C01O29 = 'AIRCAR' - IF(SUBSET .EQ. 'NC004005') C01O29 = 'ADPUPA' - - IF(SUBSET .EQ. 'ADPSFC') C01O29 = 'ADPSFC' - IF(SUBSET .EQ. 'SFCSHP') C01O29 = 'SFCSHP' - IF(SUBSET .EQ. 'SFCBOG') C01O29 = 'SFCBOG' - IF(SUBSET .EQ. 'ADPUPA') C01O29 = 'ADPUPA' - IF(SUBSET .EQ. 'AIRCFT') C01O29 = 'AIRCFT' - IF(SUBSET .EQ. 'SATWND') C01O29 = 'SATWND' - IF(SUBSET .EQ. 'SATEMP') C01O29 = 'SATEMP' - IF(SUBSET .EQ. 'AIRCAR') C01O29 = 'AIRCAR' - IF(SUBSET .EQ. 'SPSSMI') C01O29 = 'SPSSMI' - - IF(C01O29.EQ.'NONE') PRINT'(" ##IW3UNP29/C01O29 - UNKNOWN SUBSET", - $ " (=",A,") -- CONTINUE~~")', SUBSET - - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION R01O29(SUBSET,LUNIT,OBS) -C ---> formerly FUNCTION ADC - - CHARACTER*(*) SUBSET - CHARACTER*6 C01O29,ADPSUB - DIMENSION OBS(*) - - SAVE - -C FIND AN ON29/124 DATA TYPE AND CALL A TRANSLATOR -C ------------------------------------------------ - - R01O29 = 4 - ADPSUB = C01O29(SUBSET) - IF(ADPSUB .EQ. 'ADPSFC') R01O29 = R04O29(LUNIT,OBS) - IF(ADPSUB .EQ. 'SFCSHP') R01O29 = R04O29(LUNIT,OBS) - IF(ADPSUB .EQ. 'SFCBOG') R01O29 = R04O29(LUNIT,OBS) - IF(ADPSUB .EQ. 'ADPUPA') R01O29 = R03O29(LUNIT,OBS) - IF(ADPSUB .EQ. 'AIRCFT') R01O29 = R05O29(LUNIT,OBS) - IF(ADPSUB .EQ. 'AIRCAR') R01O29 = R05O29(LUNIT,OBS) - IF(ADPSUB .EQ. 'SATWND') R01O29 = R06O29(LUNIT,OBS) - IF(ADPSUB .EQ. 'SPSSMI') R01O29 = R07O29(LUNIT,OBS) - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - SUBROUTINE S01O29(SID,XOB,YOB,RHR,RCH,RSV,RSV2,ELV,ITP,RTP) -C ---> Formerly SUBROUTINE O29HDR - - COMMON/IO29DD/HDR(12),RCATS(50,150,11),IKAT(11),MCAT(11),NCAT(11) - COMMON/IO29LL/BMISS - - CHARACTER*(*) RSV,RSV2 - CHARACTER*8 COB,SID,RCT - DIMENSION IHDR(12),RHDR(12),ICATS(50,150,11) - REAL(8) BMISS - EQUIVALENCE (IHDR(1),RHDR(1)),(COB,IOB),(ICATS,RCATS) - - SAVE - - DATA OMISS/99999/ - -C INITIALIZE THE UNPACK ARRAY TO MISSINGS -C --------------------------------------- - - NCAT = 0 - RCATS = OMISS - COB = ' ' - ICATS(6,1:149,1) = IOB - ICATS(4,1:149,2) = IOB - ICATS(4,1:149,3) = IOB - ICATS(4,1:149,4) = IOB - ICATS(6,1:149,5) = IOB - ICATS(6,1:149,6) = IOB - ICATS(3,1:149,7) = IOB - ICATS(3,1:149,8) = IOB - -C WRITE THE RECEIPT TIME IN CHARACTERS -C ------------------------------------ - - RCT = '9999 ' - IF(RCH*100.LT.2401.AND.RCH*100.GT.-1) - $ WRITE(RCT,'(I4.4)') NINT(RCH*100.) - -C STORE THE ON29 HEADER INFORMATION INTO UNP FORMAT -C ------------------------------------------------- - - RHDR( 1) = OMISS - IF(YOB.LT.BMISS) RHDR( 1) = NINT(100.*YOB) -cppppp - IF(YOB.GE.BMISS) print'(" ~~IW3UNP29/S01O29: ID ",A," has a ", - $ "missing LATITUDE - on29 hdr, word 1 is set to ",G0)', - $ sid,RHDR(1) -cppppp - RHDR( 2) = OMISS - IF(XOB.LT.BMISS) RHDR( 2) = NINT(100.*MOD(720.-XOB,360.)) -cppppp - IF(XOB.GE.BMISS) print'(" ~~IW3UNP29/S01O29: ID ",A," has a ", - $ "missing LONGITUDE - on29 hdr, word 2 is set to ",G0)', - $ sid,RHDR(2) -cppppp - RHDR( 3) = OMISS - RHDR( 4) = OMISS - IF(RHR.LT.BMISS) RHDR( 4) = NINT((100.*RHR)+0.0001) -cppppp - IF(RHR.GE.BMISS) print'(" ~~IW3UNP29/S01O29: ID ",A," has a ", - $ "missing OB TIME - on29 hdr, word 4 is set to ",G0)', sid,RHDR(4) -cppppp - IF(RSV2.EQ.' ') THEN - COB = ' ' - COB(1:4) = RCT(3:4)//RSV(1:2) - IHDR(5) = IOB - COB = ' ' - COB(1:3) = RCT(1:2)//RSV(3:3) - IHDR(6) = IOB - ELSE - COB = ' ' - COB(1:4) = RSV2(3:4)//RSV(1:2) - IHDR(5) = IOB - COB = ' ' - COB(1:3) = RSV2(1:2)//RSV(3:3) - IHDR(6) = IOB - END IF - RHDR( 7) = NINT(ELV) - IHDR( 8) = ITP - IHDR( 9) = RTP - RHDR(10) = OMISS - COB = ' ' - COB(1:4) = SID(1:4) - IHDR(11) = IOB - COB = ' ' - COB(1:4) = SID(5:6)//' ' - IHDR(12) = IOB - -C STORE THE HEADER INTO A HOLDING ARRAY -C ------------------------------------- - - HDR = RHDR - - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - SUBROUTINE S02O29(ICAT,N,*) -C ---> Formerly SUBROUTINE O29CAT - - COMMON/IO29DD/HDR(12),RCATS(50,150,11),IKAT(11),MCAT(11),NCAT(11) - COMMON/IO29EE/POB(255),QOB(255),TOB(255),ZOB(255),DOB(255), - $ SOB(255),VSG(255),CLP(255),CLA(255),OB8(255), - $ CF8(255) - COMMON/IO29FF/PQM(255),QQM(255),TQM(255),ZQM(255),WQM(255), - $ QCP(255),QCA(255),Q81(255),Q82(255) - COMMON/IO29GG/PSL,STP,SDR,SSP,STM,DPD,TMX,TMI,HVZ,PRW,PW1,CCN,CHN, - $ CTL,CTM,CTH,HCB,CPT,APT,PC6,SND,P24,DOP,POW,HOW,SWD, - $ SWP,SWH,SST,SPG,SPD,SHC,SAS,WES - COMMON/IO29HH/PSQ,SPQ,SWQ,STQ,DDQ - COMMON/IO29II/PWMIN - COMMON/IO29LL/BMISS - - CHARACTER*8 COB,C11,C12 - CHARACTER*1 PQM,QQM,TQM,ZQM,WQM,QCP,QCA,Q81,Q82,PSQ,SPQ,SWQ,STQ, - $ DDQ - DIMENSION RCAT(50),JCAT(50) - REAL(8) BMISS - EQUIVALENCE (RCAT(1),JCAT(1)),(C11,HDR(11)),(C12,HDR(12)), - $ (COB,IOB) - LOGICAL SURF - - SAVE - -cppppp-ID - iprint = 0 -c if(C11(1:4)//C12(1:2).eq.'59758 ') iprint = 1 -c if(C11(1:4)//C12(1:2).eq.'59362 ') iprint = 1 -c if(C11(1:4)//C12(1:2).eq.'57957 ') iprint = 1 -c if(C11(1:4)//C12(1:2).eq.'74794 ') iprint = 1 -c if(C11(1:4)//C12(1:2).eq.'74389 ') iprint = 1 -c if(C11(1:4)//C12(1:2).eq.'96801A') iprint = 1 -cppppp-ID - - SURF = .FALSE. - GOTO 1 - -C ENTRY POINT SE01O29 FORCES DATA INTO THE SURFACE (FIRST) LEVEL -C -------------------------------------------------------------- - - ENTRY SE01O29(ICAT,N) -C ---> formerly ENTRY O29SFC - SURF = .TRUE. - -C CHECK THE PARAMETERS COMING IN -C ------------------------------ - -1 KCAT = 0 - DO I = 1,11 - IF(ICAT.EQ.IKAT(I)) THEN - KCAT = I - GO TO 991 - END IF - ENDDO - - 991 CONTINUE - -C PARAMETER ICAT (ON29 CATEGORY) OUT OF BOUNDS RETURNS A 999 -C ---------------------------------------------------------- - - IF(KCAT.EQ.0) THEN - PRINT'(" ##IW3UNP29/S02O29 - ON29 CATEGORY ",I0," OUT OF ", - $ "BOUNDS -- IER = 999")', ICAT - RETURN 1 - END IF - -C PARAMETER N (LEVEL INDEX) OUT OF BOUNDS RETURNS A 999 -C ----------------------------------------------------- - - IF(N.GT.255) THEN - PRINT'(" ##IW3UNP29/S02O29 - LEVEL INDEX ",I0," EXCEEDS 255 ", - $ "-- IER = 999")', N - RETURN 1 - END IF - -C MAKE A MISSING LEVEL AND RETURN WHEN N=0 (NOT ALLOWED FOR CAT 01) -C ----------------------------------------------------------------- - - IF(N.EQ.0) THEN - IF(KCAT.EQ.1) RETURN - NCAT(KCAT) = MIN(149,NCAT(KCAT)+1) -cppppp - if(iprint.eq.1) - $ print'(" To prepare for sfc. data, write all missings on ", - $ "lvl ",I0," for cat ",I0)', ncat(kcat),kcat -cppppp - RETURN - END IF - -C FIGURE OUT WHICH LEVEL TO UPDATE AND RESET THE LEVEL COUNTER -C ------------------------------------------------------------ - - IF(KCAT.EQ.1) THEN - L = I04O29(POB(N)*.1) - IF(L.EQ.999999) GO TO 9999 - -C BAD MANDATORY LEVEL RETURNS A 999 -C --------------------------------- - - IF(L.LE.0) THEN - PRINT'(" ##IW3UNP29/S02O29 - BAD MANDATORY LEVEL (P = ", - $ G0,") -- IER = 999")', POB(N) - RETURN 1 - END IF - NCAT(KCAT) = MAX(NCAT(KCAT),L) -cppppp - if(iprint.eq.1) - $ print'(" Will write cat. 1 data on lvl ",I0," for cat ",I0, - $ ", - total no. cat. 1 lvls processed so far = ",I0)', - $ L,kcat,ncat(kcat) -cppppp - ELSEIF(SURF) THEN - L = 1 - NCAT(KCAT) = MAX(NCAT(KCAT),1) -cppppp - if(iprint.eq.1) - $ print'(" Will write cat. ",I0," SURFACE data on lvl ",I0, - $ ", - total no. cat. ",I0," lvls processed so far = ",I0)', - $ kcat,L,kcat,ncat(kcat) -cppppp - ELSE - L = MIN(149,NCAT(KCAT)+1) - IF(L.EQ.149) THEN -cppppp - print'(" ~~IW3UNP29/S02O29: ID ",A," - This cat. ",I0, - $ " level cannot be processed because the limit has already", - $ " been reached")', c11(1:4)//c12(1:2),kcat -cppppp - RETURN - END IF - NCAT(KCAT) = L -cppppp - if(iprint.eq.1) - $ print'(" Will write cat. ",I0," NON-SFC data on lvl ",I0, - $ ", - total no. cat. ",I0," lvls processed so far = ",I0)', - $ kcat,L,kcat,ncat(kcat) -cppppp - END IF - -C EACH CATEGORY NEEDS A SPECIFIC DATA ARRANGEMENT -C ----------------------------------------------- - - COB = ' ' - IF(ICAT.EQ.1) THEN - RCAT(1) = MIN(NINT(ZOB(N)),NINT(RCATS(1,L,KCAT))) - RCAT(2) = MIN(NINT(TOB(N)),NINT(RCATS(2,L,KCAT))) - RCAT(3) = MIN(NINT(QOB(N)),NINT(RCATS(3,L,KCAT))) - RCAT(4) = MIN(NINT(DOB(N)),NINT(RCATS(4,L,KCAT))) - RCAT(5) = MIN(NINT(SOB(N)),NINT(RCATS(5,L,KCAT))) - COB(1:4) = ZQM(N)//TQM(N)//QQM(N)//WQM(N) - JCAT(6) = IOB - ELSEIF(ICAT.EQ.2) THEN - RCAT(1) = MIN(NINT(POB(N)),99999) - RCAT(2) = MIN(NINT(TOB(N)),99999) - RCAT(3) = MIN(NINT(QOB(N)),99999) - COB(1:3) = PQM(N)//TQM(N)//QQM(N) - JCAT(4) = IOB - ELSEIF(ICAT.EQ.3) THEN - RCAT(1) = MIN(NINT(POB(N)),99999) - RCAT(2) = MIN(NINT(DOB(N)),99999) - RCAT(3) = MIN(NINT(SOB(N)),99999) - -C MARK THE TROPOPAUSE LEVEL IN CAT. 3 - - IF(NINT(VSG(N)).EQ.16) PQM(N) = 'T' - -C MARK THE MAXIMUM WIND LEVEL IN CAT. 3 - - IF(NINT(VSG(N)).EQ. 8) THEN - PQM(N) = 'W' - IF(POB(N).EQ.PWMIN) PQM(N) = 'X' - END IF - COB(1:2) = PQM(N)//WQM(N) - JCAT(4) = IOB - ELSEIF(ICAT.EQ.4) THEN - RCAT(1) = MIN(NINT(ZOB(N)),99999) - RCAT(2) = MIN(NINT(DOB(N)),99999) - RCAT(3) = MIN(NINT(SOB(N)),99999) - COB(1:2) = ZQM(N)//WQM(N) - JCAT(4) = IOB - ELSEIF(ICAT.EQ.5) THEN - RCAT(1) = MIN(NINT(POB(N)),99999) - RCAT(2) = MIN(NINT(TOB(N)),99999) - RCAT(3) = MIN(NINT(QOB(N)),99999) - RCAT(4) = MIN(NINT(DOB(N)),99999) - RCAT(5) = MIN(NINT(SOB(N)),99999) - COB(1:4) = PQM(N)//TQM(N)//QQM(N)//WQM(N) - JCAT(6) = IOB - ELSEIF(ICAT.EQ.6) THEN - RCAT(1) = MIN(NINT(ZOB(N)),99999) - RCAT(2) = MIN(NINT(TOB(N)),99999) - RCAT(3) = MIN(NINT(QOB(N)),99999) - RCAT(4) = MIN(NINT(DOB(N)),99999) - RCAT(5) = MIN(NINT(SOB(N)),99999) - COB(1:4) = ZQM(N)//TQM(N)//QQM(N)//WQM(N) - JCAT(6) = IOB - ELSEIF(ICAT.EQ.7) THEN - RCAT(1) = MIN(NINT(CLP(N)),99999) - RCAT(2) = MIN(NINT(CLA(N)),99999) - COB(1:2) = QCP(N)//QCA(N) - JCAT(3) = IOB - ELSEIF(ICAT.EQ.8) THEN - RCAT(1) = MIN(NINT(OB8(N)),99999) - RCAT(2) = MIN(NINT(CF8(N)),99999) - COB(1:2) = Q81(N)//Q82(N) - JCAT(3) = IOB - ELSEIF(ICAT.EQ.51) THEN - RCAT( 1) = MIN(NINT(PSL),99999) - RCAT( 2) = MIN(NINT(STP),99999) - RCAT( 3) = MIN(NINT(SDR),99999) - RCAT( 4) = MIN(NINT(SSP),99999) - RCAT( 5) = MIN(NINT(STM),99999) - RCAT( 6) = MIN(NINT(DPD),99999) - RCAT( 7) = MIN(NINT(TMX),99999) - RCAT( 8) = MIN(NINT(TMI),99999) - COB(1:4) = PSQ//SPQ//SWQ//STQ - JCAT(9) = IOB - COB = ' ' - COB(1:1) = DDQ - JCAT(10) = IOB - JCAT(11) = MIN(NINT(HVZ),99999) - JCAT(12) = MIN(NINT(PRW),99999) - JCAT(13) = MIN(NINT(PW1),99999) - JCAT(14) = MIN(NINT(CCN),99999) - JCAT(15) = MIN(NINT(CHN),99999) - JCAT(16) = MIN(NINT(CTL),99999) - JCAT(17) = MIN(NINT(HCB),99999) - JCAT(18) = MIN(NINT(CTM),99999) - JCAT(19) = MIN(NINT(CTH),99999) - JCAT(20) = MIN(NINT(CPT),99999) - RCAT(21) = MIN(ABS(NINT(APT)),99999) - IF(CPT.GE.BMISS.AND.APT.LT.0.) - $ RCAT(21) = MIN(ABS(NINT(APT))+500,99999) - ELSEIF(ICAT.EQ.52) THEN - JCAT( 1) = MIN(NINT(PC6),99999) - JCAT( 2) = MIN(NINT(SND),99999) - JCAT( 3) = MIN(NINT(P24),99999) - JCAT( 4) = MIN(NINT(DOP),99999) - JCAT( 5) = MIN(NINT(POW),99999) - JCAT( 6) = MIN(NINT(HOW),99999) - JCAT( 7) = MIN(NINT(SWD),99999) - JCAT( 8) = MIN(NINT(SWP),99999) - JCAT( 9) = MIN(NINT(SWH),99999) - JCAT(10) = MIN(NINT(SST),99999) - JCAT(11) = MIN(NINT(SPG),99999) - JCAT(12) = MIN(NINT(SPD),99999) - JCAT(13) = MIN(NINT(SHC),99999) - JCAT(14) = MIN(NINT(SAS),99999) - JCAT(15) = MIN(NINT(WES),99999) - ELSE - -C UNSUPPORTED CATEGORY RETURNS A 999 -C ---------------------------------- - - PRINT'(" ##IW3UNP29/S02O29 - CATEGORY ",I0," NOT SUPPORTED ", - $ "-- IER = 999")', ICAT - RETURN 1 - END IF - -C TRANSFER THE LEVEL DATA INTO THE HOLDING ARRAY AND EXIT -C ------------------------------------------------------- - - DO I = 1,MCAT(KCAT) - RCATS(I,L,KCAT) = RCAT(I) - ENDDO - - RETURN - 9999 CONTINUE - RETURN 1 - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - SUBROUTINE S03O29(UNP,SUBSET,*,*) -C ---> Formerly SUBROUTINE O29UNP - - COMMON/IO29DD/HDR(12),RCATS(50,150,11),IKAT(11),MCAT(11),NCAT(11) - - DIMENSION RCAT(50),JCAT(50),UNP(*) - CHARACTER*8 SUBSET - EQUIVALENCE (RCAT(1),JCAT(1)) - - SAVE - -C CALL TO SORT CATEGORIES 02, 03, 04, AND 08 LEVELS -C ------------------------------------------------- - - CALL S04O29 - -C TRANSFER DATA FROM ALL CATEGORIES INTO UNP ARRAY & SET POINTERS -C --------------------------------------------------------------- - - INDX = 43 - JCAT = 0 - NLEVTO = 0 - NLEVC8 = 0 - - DO K = 1,11 - JCAT(2*K+11) = NCAT(K) - IF(K.NE.7.AND.K.NE.8.AND.K.NE.11) THEN - NLEVTO = NLEVTO + NCAT(K) - ELSE IF(K.EQ.8) THEN - NLEVC8 = NLEVC8 + NCAT(K) - END IF - IF(NCAT(K).GT.0) JCAT(2*K+12) = INDX - IF(NCAT(K).EQ.0) JCAT(2*K+12) = 0 - DO J = 1,NCAT(K) - DO I = 1,MCAT(K) - -C UNPACKED ON29 REPORT CONTAINS MORE THAN 1608 WORDS - RETURNS A 999 -C ------------------------------------------------------------------ - - IF(INDX.GT.1608) THEN - PRINT'(" ##IW3UNP29/S03O29 - UNPKED ON29 RPT CONTAINS ", - $ I0," WORDS, > LIMIT OF 1608 -- IER = 999")', INDX - RETURN 1 - END IF - UNP(INDX) = RCATS(I,J,K) - INDX = INDX+1 - ENDDO - ENDDO - ENDDO - -C RETURN WITHOUT PROCESSING THIS REPORT IF NO DATA IN CAT. 1-6, 51, 52 -C (UNLESS SSM/I REPORT, THEN DO NOT RETURN UNLESS ALSO NO CAT. 8 DATA) -C -------------------------------------------------------------------- - - IF(NLEVTO.EQ.0) THEN - IF(SUBSET(1:5).NE.'NC012') THEN - RETURN 2 - ELSE - IF(NLEVC8.EQ.0) RETURN 2 - END IF - END IF - -C TRANSFER THE HEADER AND POINTER ARRAYS INTO UNP -C ----------------------------------------------- - - UNP(1:12) = HDR - UNP(13:42) = RCAT(13:42) - - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - SUBROUTINE S04O29 -C ---> Formerly SUBROUTINE O29SRT - - COMMON/IO29DD/HDR(12),RCATS(50,150,11),IKAT(11),MCAT(11),NCAT(11) -cppppp - character*8 c11,c12,sid -cppppp - - DIMENSION RCAT(50,150),IORD(150),IWORK(65536),SCAT(50,150),RCTL(3) -cppppp - EQUIVALENCE (C11,HDR(11)),(C12,HDR(12)) -cppppp - - SAVE - -cppppp - sid = c11(1:4)//c12(1:4) -cppppp - -C SORT CATEGORIES 2, 3, AND 4 - LEAVE THE FIRST LEVEL IN EACH INTACT -C ------------------------------------------------------------------ - - DO K=2,4 - IF(NCAT(K).GT.1) THEN - DO J=1,NCAT(K)-1 - DO I=1,MCAT(K) - SCAT(I,J) = RCATS(I,J+1,K) - ENDDO - ENDDO - CALL ORDERS(2,IWORK,SCAT(1,1),IORD,NCAT(K)-1,50,8,2) - RCTL = 10E9 - DO J=1,NCAT(K)-1 - IF(K.LT.4) JJ = IORD((NCAT(K)-1)-J+1) - IF(K.EQ.4) JJ = IORD(J) - DO I=1,MCAT(K) - RCAT(I,J) = SCAT(I,JJ) - ENDDO - IDUP = 0 - IF(NINT(RCAT(1,J)).EQ.NINT(RCTL(1))) THEN - IF(NINT(RCAT(2,J)).EQ.NINT(RCTL(2)).AND. - $ NINT(RCAT(3,J)).EQ.NINT(RCTL(3))) THEN -cppppp - if(k.ne.4) then - print'(" ~~@@IW3UNP29/S04O29: ID ",A," has a ", - $ "dupl. cat. ",I0," lvl (all data) at ",G0," mb -- lvl will be ", - $ "excluded from processing")', sid,k,rcat(1,j)*.1 - else - print'(" ~~@@IW3UNP29/S04O29: ID ",A," has a ", - $ "dupl. cat. ",I0," lvl (all data) at ",G0," m -- lvl will be ", - $ "excluded from processing")', sid,k,rcat(1,j) - end if -cppppp - IDUP = 1 - ELSE -cppppp - if(k.ne.4) then - print'(" ~~@@#IW3UNP29/S04O29: ID ",A," has a ", - $ "dupl. cat. ",I0," press. lvl (data differ) at ",G0," mb -- lvl", - $ " will NOT be excluded")', sid,k,rcat(1,j)*.1 - else - print'(" ~~@@#IW3UNP29/S04O29: ID ",A," has a ", - $ "dupl. cat. ",I0," height lvl (data differ) at ",G0," m -- lvl ", - $ "will NOT be excluded")', sid,k,rcat(1,j) - end if -cppppp - END IF - END IF - RCTL = RCAT(1:3,J) - IF(IDUP.EQ.1) RCAT(1,J) = 10E8 - ENDDO - JJJ = 1 - DO J=2,NCAT(K) - IF(RCAT(1,J-1).GE.10E8) GO TO 887 - JJJ = JJJ + 1 - DO I=1,MCAT(K) - RCATS(I,JJJ,K) = RCAT(I,J-1) - ENDDO - 887 CONTINUE - ENDDO -cppppp - if(jjj.ne.NCAT(K)) - $ print'(" ~~@@IW3UNP29/S04O29: ID ",A," has had ",I0, - $ " lvls removed due to their being duplicates")', - $ sid,NCAT(K)-jjj -cppppp - ncat(k) = jjj - end if - IF(NCAT(K).EQ.1) THEN - IF(MIN(RCATS(1,1,K),RCATS(2,1,K),RCATS(3,1,K)).GT.99998.8) - $ NCAT(K) = 0 - END IF - ENDDO - -C SORT CATEGORY 08 BY CODE FIGURE -C ------------------------------- - - DO K=8,8 - IF(NCAT(K).GT.1) THEN - CALL ORDERS(2,IWORK,RCATS(2,1,K),IORD,NCAT(K),50,8,2) - DO J=1,NCAT(K) - DO I=1,MCAT(K) - RCAT(I,J) = RCATS(I,IORD(J),K) - ENDDO - ENDDO - DO J=1,NCAT(K) - DO I=1,MCAT(K) - RCATS(I,J,K) = RCAT(I,J) - ENDDO - ENDDO - END IF - ENDDO - -C NORMAL EXIT -C ----------- - - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - SUBROUTINE S05O29 -C ---> Formerly SUBROUTINE O29INX - - COMMON/IO29EE/OBS(255,11) - COMMON/IO29FF/QMS(255,9) - COMMON/IO29GG/SFO(34) - COMMON/IO29HH/SFQ(5) - COMMON/IO29LL/BMISS - - CHARACTER*1 QMS,SFQ - - REAL(8) BMISS - - SAVE - -C SET THE INPUT DATA ARRAYS TO MISSING OR BLANK -C --------------------------------------------- - - OBS = BMISS - QMS = ' ' - SFO = BMISS - SFQ = ' ' - - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION I04O29(P) -C ---> formerly FUNCTION MANO29 - - COMMON/IO29JJ/ISET,MANLIN(1001) - - SAVE - - IF(ISET.EQ.0) THEN - MANLIN = 0 - - MANLIN(1000) = 1 - MANLIN(850) = 2 - MANLIN(700) = 3 - MANLIN(500) = 4 - MANLIN(400) = 5 - MANLIN(300) = 6 - MANLIN(250) = 7 - MANLIN(200) = 8 - MANLIN(150) = 9 - MANLIN(100) = 10 - MANLIN(70) = 11 - MANLIN(50) = 12 - MANLIN(30) = 13 - MANLIN(20) = 14 - MANLIN(10) = 15 - MANLIN(7) = 16 - MANLIN(5) = 17 - MANLIN(3) = 18 - MANLIN(2) = 19 - MANLIN(1) = 20 - - ISET = 1 - END IF - - IP = NINT(P*10.) - - IF(IP.GT.10000 .OR. IP.LT.10 .OR. MOD(IP,10).NE.0) THEN - I04O29 = 0 - ELSE - I04O29 = MANLIN(IP/10) - END IF - - RETURN - - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION R02O29() -C ---> formerly FUNCTION ONFUN - - COMMON/IO29LL/BMISS - - CHARACTER*8 SUBSET,RPID - LOGICAL L02O29,L03O29 - INTEGER KKK(0:99),KKKK(49) - REAL(8) BMISS - - SAVE - - DATA GRAV/9.8/,CM2K/1.94/,TZRO/273.15/ - DATA KKK /5*90,16*91,30*92,49*93/ - DATA KKKK/94,2*95,6*96,10*97,30*98/ - - PRS1(Z) = 1013.25 * (((288.15 - (.0065 * Z))/288.15)**5.256) - PRS2(Z) = 226.3 * EXP(1.576106E-4 * (11000. - Z)) - PRS3(PMND,TEMP,Z,ZMND) - $ = PMND * (((TEMP - (.0065 * (Z - ZMND)))/TEMP)**5.256) - ES(T) = 6.1078 * EXP((17.269 * (T-273.16))/((T-273.16)+237.3)) - QFRMTP(T,PPPP) = (0.622 * ES(T))/(PPPP-(0.378 * ES(T))) - HGTF(P) = (1.-(P/1013.25)**(1./5.256))*(288.15/.0065) - - R02O29 = 0 - - RETURN - - ENTRY E01O29(PRS) -C ---> formerly ENTRY ONPRS - IF(PRS.LT.BMISS) E01O29 = NINT(PRS*.1) - IF(PRS.GE.BMISS) E01O29 = BMISS - RETURN - ENTRY E37O29(PMND,TEMP,HGT,ZMND,TQM) -C ---> formerly ENTRY ONPFHT - IF(HGT.GE.BMISS) THEN - E37O29 = BMISS - ELSE - IF(HGT.LE.11000) THEN - P = PRS1(HGT) - ELSE - P = PRS2(HGT) - END IF - IF(MAX(PMND,ZMND).GE.BMISS) THEN - E37O29 = P - RETURN - END IF - IF(TEMP.GE.9999.) TEMP = BMISS - IF(TQM.GE.BMISS) TQM = 2 - IF(TEMP.GE.BMISS.OR.TQM.GE.4) CALL W3FA03(P,D1,TEMP,D2) - Q = QFRMTP(TEMP,P) - TVIRT = TEMP * (1.0 + (0.61 * Q)) - E37O29 = PRS3(PMND,TVIRT,HGT,ZMND) - END IF - RETURN - ENTRY E03O29(PRS) -C ---> formerly ENTRY ONHFP - IF(PRS.LT.BMISS) E03O29 = HGTF(PRS) - IF(PRS.GE.BMISS) E03O29 = BMISS - RETURN - ENTRY E04O29(WDR,WSP) -C ---> formerly ENTRY ONWDR - E04O29 = WDR - RETURN - ENTRY E05O29(WDR,WSP) -C ---> formerly ENTRY ONWSP - IF(WSP.LT.BMISS) THEN - E05O29 = (WSP*CM2K) - E05O29 = E05O29 + 0.0000001 - ELSE - E05O29 = BMISS - END IF - RETURN - ENTRY E06O29(TMP) -C ---> formerly ENTRY ONTMP - ITMP = NINT(TMP*100.) - ITZRO = NINT(TZRO*100.) - IF(TMP.LT.BMISS) E06O29 = NINT((ITMP - ITZRO)*0.1) - IF(TMP.GE.BMISS) E06O29 = BMISS - RETURN - ENTRY E07O29(DPD,TMP) -C ---> formerly ENTRY ONDPD - IF(DPD.LT.BMISS .AND. TMP.LT.BMISS) E07O29 = (TMP-DPD)*10. - IF(DPD.GE.BMISS .OR. TMP.GE.BMISS) E07O29 = BMISS - RETURN - ENTRY E08O29(HGT) -C ---> formerly ENTRY ONHGT - E08O29 = HGT - IF(HGT.LT.BMISS) E08O29 = (HGT/GRAV) - RETURN - ENTRY E09O29(HVZ) -C ---> formerly ENTRY ONHVZ - IF(HVZ.GE.BMISS.OR.HVZ.LT.0.) THEN - E09O29 = BMISS - ELSE IF(NINT(HVZ).LT.6000) THEN - E09O29 = MIN(INT(NINT(HVZ)/100),50) - ELSE IF(NINT(HVZ).LT.30000) THEN - E09O29 = INT(NINT(HVZ)/1000) + 50 - ELSE IF(NINT(HVZ).LE.70000) THEN - E09O29 = INT(NINT(HVZ)/5000) + 74 - ELSE - E09O29 = 89 - END IF - RETURN - ENTRY E10O29(PRW) -C ---> formerly ENTRY ONPRW - E10O29 = BMISS - IF(PRW.LT.BMISS) E10O29 = NINT(MOD(PRW,100.)) - RETURN - ENTRY E11O29(PAW) -C ---> formerly ENTRY ONPAW - E11O29 = BMISS - IF(PAW.LT.BMISS) E11O29 = NINT(MOD(PAW,10.)) - RETURN - ENTRY E12O29(CCN) -C ---> formerly ENTRY ONCCN - IF(NINT(CCN).EQ.0) THEN - E12O29 = 0 - ELSE IF(CCN.LT. 15) THEN - E12O29 = 1 - ELSE IF(CCN.LT. 35) THEN - E12O29 = 2 - ELSE IF(CCN.LT. 45) THEN - E12O29 = 3 - ELSE IF(CCN.LT. 55) THEN - E12O29 = 4 - ELSE IF(CCN.LT. 65) THEN - E12O29 = 5 - ELSE IF(CCN.LT. 85) THEN - E12O29 = 6 - ELSE IF(CCN.LT.100) THEN - E12O29 = 7 - ELSE IF(NINT(CCN).EQ.100) THEN - E12O29 = 8 - ELSE - E12O29 = BMISS - END IF - RETURN - ENTRY E13O29(CLA) -C ---> formerly ENTRY ONCLA - E13O29 = BMISS - IF(CLA.EQ.0) E13O29 = 0 - IF(CLA.EQ.1) E13O29 = 5 - IF(CLA.EQ.2) E13O29 = 25 - IF(CLA.EQ.3) E13O29 = 40 - IF(CLA.EQ.4) E13O29 = 50 - IF(CLA.EQ.5) E13O29 = 60 - IF(CLA.EQ.6) E13O29 = 75 - IF(CLA.EQ.7) E13O29 = 95 - IF(CLA.EQ.8) E13O29 = 100 - RETURN - ENTRY E14O29(CCL,CCM) -C ---> formerly ENTRY ONCHN - E14O29 = CCL - IF(NINT(E14O29).EQ.0) E14O29 = CCM - IF(NINT(E14O29).LT.10) RETURN - IF(NINT(E14O29).EQ.10) THEN - E14O29 = 9. - ELSE IF(NINT(E14O29).EQ.15) THEN - E14O29 = 10. - ELSE - E14O29 = BMISS - END IF - RETURN - ENTRY E15O29(CTLMH) -C ---> formerly ENTRY ONCTL, ONCTM, ONCTH - E15O29 = CTLMH - RETURN - ENTRY E18O29(CHL,CHM,CHH,CTL,CTM,CTH) -C ---> formerly ENTRY ONHCB - IF(NINT(MAX(CTL,CTM,CTH)).EQ.0) THEN - E18O29 = 9 - RETURN - END IF - E18O29 = BMISS - IF(CHH.LT.BMISS) E18O29 = CHH - IF(CHM.LT.BMISS) E18O29 = CHM - IF(CHL.LT.BMISS) E18O29 = CHL - IF(E18O29.GE.BMISS.OR.E18O29.LT.0) RETURN - IF(E18O29.LT. 150) THEN - E18O29 = 0 - ELSE IF(E18O29.LT. 350) THEN - E18O29 = 1 - ELSE IF(E18O29.LT. 650) THEN - E18O29 = 2 - ELSE IF(E18O29.LT. 950) THEN - E18O29 = 3 - ELSE IF(E18O29.LT.1950) THEN - E18O29 = 4 - ELSE IF(E18O29.LT.3250) THEN - E18O29 = 5 - ELSE IF(E18O29.LT.4950) THEN - E18O29 = 6 - ELSE IF(E18O29.LT.6750) THEN - E18O29 = 7 - ELSE IF(E18O29.LT.8250) THEN - E18O29 = 8 - ELSE - E18O29 = 9 - END IF - RETURN - ENTRY E19O29(CPT) -C ---> formerly ENTRY ONCPT - E19O29 = BMISS - IF(NINT(CPT).GT.-1.AND.NINT(CPT).LT.9) E19O29 = CPT - RETURN - ENTRY E20O29(PRC) -C ---> formerly ENTRY ONPRC - E20O29 = PRC - IF(PRC.LT.0.) THEN - E20O29 = 9998 - ELSE IF(PRC.LT.BMISS) THEN - E20O29 = NINT(PRC*3.937) - END IF - RETURN - ENTRY E21O29(SND) -C ---> formerly ENTRY ONSND - E21O29 = SND - IF(SND.LT.0.) THEN - E21O29 = 998 - ELSE IF(SND.LT.BMISS) THEN - E21O29 = NINT(SND*39.37) - END IF - RETURN - ENTRY E22O29(PC6) -C ---> formerly ENTRY ONDOP - E22O29 = BMISS - IF(PC6.LT.BMISS) E22O29 = 1 - RETURN - ENTRY E23O29(PER) -C ---> formerly ENTRY ONPOW, ONSWP - E23O29 = NINT(PER) - RETURN - ENTRY E24O29(HGT) -C ---> formerly ENTRY ONHOW, ONSWH - E24O29 = HGT - IF(HGT.LT.BMISS) E24O29 = NINT(2.*HGT) - RETURN - ENTRY E25O29(SWD) -C ---> formerly ENTRY ONSWD - E25O29 = SWD - IF(SWD.EQ.0) THEN - E25O29 = 0 - ELSE IF(SWD.LT.5) THEN - E25O29 = 36 - ELSE IF(SWD.LT.BMISS) THEN - E25O29 = NINT((SWD+.001)*.1) - END IF - RETURN - ENTRY E28O29(SPG) -C ---> formerly ENTRY ONSPG - E28O29 = SPG - RETURN - ENTRY E29O29(SPD) -C ---> formerly ENTRY ONSPD - E29O29 = SPD - RETURN - ENTRY E30O29(SHC) -C ---> formerly ENTRY ONSHC - E30O29 = BMISS - IF(NINT(SHC).GT.-1.AND.NINT(SHC).LT.9) E30O29 = NINT(SHC) - RETURN - ENTRY E31O29(SAS) -C ---> formerly ENTRY ONSAS - E31O29 = BMISS - IF(NINT(SAS).GT.-1.AND.NINT(SAS).LT.10) E31O29 = NINT(SAS) - RETURN - ENTRY E32O29(WES) -C ---> formerly ENTRY ONWES - E32O29 = WES - RETURN - ENTRY E33O29(SUBSET,RPID) -C ---> formerly ENTRY ONRTP - E33O29 = BMISS - IF(SUBSET(1:5).EQ.'NC000'.AND.L02O29(RPID) ) E33O29 = 511 - IF(SUBSET(1:5).EQ.'NC000'.AND.L03O29(RPID) ) E33O29 = 512 - IF(SUBSET.EQ.'NC001001'.AND.RPID.NE.'SHIP') E33O29 = 522 - IF(SUBSET.EQ.'NC001001'.AND.RPID.EQ.'SHIP') E33O29 = 523 - IF(SUBSET.EQ.'NC001002') E33O29 = 562 - IF(SUBSET.EQ.'NC001003') E33O29 = 561 - IF(SUBSET.EQ.'NC001004') E33O29 = 531 - IF(SUBSET.EQ.'NC001006') E33O29 = 551 - IF(SUBSET.EQ.'NC002001') THEN - -C LAND RADIOSONDE - FIXED -C ----------------------- - - E33O29 = 011 - IF(L03O29(RPID)) E33O29 = 012 - IF(RPID(1:4).EQ.'CLAS') E33O29 = 013 - END IF - IF(SUBSET.EQ.'NC002002') THEN - -C LAND RADIOSONDE - MOBILE -C ------------------------ - - E33O29 = 013 - END IF - IF(SUBSET.EQ.'NC002003') THEN - -C SHIP RADIOSONDE -C --------------- - - E33O29 = 022 - IF(RPID(1:4).EQ.'SHIP') E33O29 = 023 - END IF - IF(SUBSET.EQ.'NC002004') THEN - -C DROPWINSONDE -C ------------- - - E33O29 = 031 - END IF - IF(SUBSET.EQ.'NC002005') THEN - -C PIBAL -C ----- - - E33O29 = 011 - IF(L03O29(RPID)) E33O29 = 012 - END IF - - IF(SUBSET.EQ.'NC004001') E33O29 = 041 - IF(SUBSET.EQ.'NC004002') E33O29 = 041 - IF(SUBSET.EQ.'NC004003') E33O29 = 041 - IF(SUBSET.EQ.'NC004004') E33O29 = 041 - IF(SUBSET.EQ.'NC004005') E33O29 = 031 - IF(SUBSET(1:5).EQ.'NC005') E33O29 = 063 - RETURN - ENTRY E34O29(HGT,Z100) -C ---> formerly ENTRY ONFIX -C - With Jeff Ator's fix on 1/30/97, don't need this anymore -cdak HGT0 = HGT -cdak IF(MOD(NINT(HGT),300).EQ.0.OR.MOD(NINT(HGT),500).EQ.0) -cdak $ HGT = HGT * 1.016 - -C ALL WINDS-BY-HEIGHT HEIGHTS ARE TRUNCATED DOWN TO THE NEXT -C 10 METER LEVEL IF PART DD (ABOVE 100 MB LEVEL) (ON29 CONVENTION) -C ----------------------------------------------------------------- - - IF(HGT.GT.Z100) THEN - IF(MOD(NINT(HGT),10).NE.0) HGT = INT(HGT/10.) * 10 - E34O29 = NINT(HGT) - ELSE -C - With Jeff Ator's fix on 1/30/97, don't need this anymore -cdak IF(HGT.NE.HGT0) THEN -cdak IF(MOD(NINT(HGT0),1500).EQ.0) HGT = HGT - 1.0 -cdak ELSE - IF(MOD(NINT(HGT/1.016),1500).EQ.0) HGT = NINT(HGT - 1.0) -cdak END IF - E34O29 = INT(HGT) - END IF - RETURN - ENTRY E38O29(HVZ) - IF(HVZ.GE.BMISS.OR.HVZ.LT.0.) THEN - E38O29 = BMISS - ELSE IF(NINT(HVZ).LT.1000) THEN - KK = MIN(INT(NINT(HVZ)/10),99) - E38O29 = KKK(KK) - ELSE IF(NINT(HVZ).LT.50000) THEN - KK = MIN(INT(NINT(HVZ)/1000),49) - E38O29 = KKKK(KK) - ELSE - E38O29 = 99 - END IF - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION C02O29() -C ---> formerly FUNCTION ONCHR - CHARACTER*8 C02O29,E35O29,E36O29 - CHARACTER*1 CPRT(0:11),CMR29(0:15) - - SAVE - -C (NOTE: Prior to mid-March 1999, a purge or reject flag on pressure -C was set to 6 (instead of 14 or 12, resp.) to get around the -C 3-bit limit to ON29 pressure q.m. mnemonic "QMPR". The 3-bit -C limit on "QMPR" was changed to 4-bits with a decoder change -C in February 1999. However, the codes that write the q.m.'s -C out (EDTBUFR and QUIPC) were not changed to write out 14 or -C 12 for purge or reject until mid-March 1999. In order to -C allow old runs to work properly, a q.m. of 6 will continue -C to be interpreted as a "P". This would have to change if -C q.m.=6 ever has a defined meaning.) - -C Code Table Value: 0 1 2 3 4 5 6 7 - - DATA CMR29 /'H','A',' ','Q','C','F','P','F', - -C Code Table Value: 8 9 10 11 12 13 14 15 - - . 'F','F','O','B','R','F','P','F'/ - - DATA CPRT /' ',' ',' ',' ','A','B','C','D','I','J','K','L'/ - - C02O29 = ' ' - RETURN - ENTRY E35O29(QMK) -C ---> formerly ENTRY ONQMK - IF(QMK.GE.0 .AND. QMK.LE.15) E35O29 = CMR29(NINT(QMK)) - IF(QMK.LT.0 .OR. QMK.GT.15) E35O29 = ' ' - RETURN - ENTRY E36O29(NPRT) -C ---> formerly ENTRY ONPRT - E36O29 = ' ' - IF(NPRT.LT.12) E36O29 = CPRT(NPRT)//' ' - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION L01O29() -C ---> formerly FUNCTION ONLOG - CHARACTER*8 RPID - LOGICAL L01O29,L02O29,L03O29 - - SAVE - - L01O29 = .TRUE. - - RETURN - - ENTRY L02O29(RPID) -C ---> formerly ENTRY ONBKS - L02O29 = .FALSE. - READ(RPID,'(I5)',ERR=1) IBKS - L02O29 = .TRUE. -1 RETURN - ENTRY L03O29(RPID) -C ---> formerly ENTRY ONCAL - L03O29 = .TRUE. - READ(RPID,'(I5)',ERR=2) IBKS - L03O29 = .FALSE. -2 RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION R03O29(LUNIT,OBS) -C ---> formerly FUNCTION ADPUPA - - COMMON/IO29DD/HDR(12),RCATS(50,150,11),IKAT(11),MCAT(11),NCAT(11) - COMMON/IO29EE/POB(255),QOB(255),TOB(255),ZOB(255),DOB(255), - $ SOB(255),VSG(255),CLP(255),CLA(255),OB8(255), - $ CF8(255) - COMMON/IO29FF/PQM(255),QQM(255),TQM(255),ZQM(255),WQM(255), - $ QCP(255),QCA(255),Q81(255),Q82(255) - COMMON/IO29CC/SUBSET,IDAT10 - COMMON/IO29BB/KNDX,KSKACF(8),KSKUPA,KSKSFC,KSKSAT,KSKSMI - COMMON/IO29II/PWMIN - COMMON/IO29LL/BMISS - - CHARACTER*80 HDSTR,LVSTR,QMSTR,RCSTR - CHARACTER*8 SUBSET,SID,E35O29,E36O29,RSV,RSV2 - CHARACTER*1 PQM,QQM,TQM,ZQM,WQM,QCP,QCA,Q81,Q82,PQML - REAL(8) RID_8,HDR_8(12),VSG_8(255) - REAL(8) RCT_8(5,255),ARR_8(10,255) - REAL(8) RAT_8(255),RMORE_8(4),RGP10_8(255),RPMSL_8,RPSAL_8 - REAL(8) BMISS - INTEGER IHBLCS(0:9) - DIMENSION OBS(*),RCT(5,255),ARR(10,255) - DIMENSION RAT(255),RMORE(4),RGP10(255) - DIMENSION P2(255),P8(255),P16(255) - - EQUIVALENCE (RID_8,SID) - LOGICAL L02O29 - - SAVE - - DATA HDSTR/'NULL CLON CLAT HOUR MINU SELV '/ - DATA LVSTR/'PRLC TMDP TMDB GP07 GP10 WDIR WSPD '/ - DATA QMSTR/'QMPR QMAT QMDD QMGP QMWN '/ - DATA RCSTR/'RCHR RCMI RCTS '/ - - DATA IHBLCS/25,75,150,250,450,800,1250,1750,2250,2500/ - - PRS1(Z) = 1013.25 * (((288.15 - (.0065 * Z))/288.15)**5.256) - PRS2(Z) = 226.3 * EXP(1.576106E-4 * (11000. - Z)) - -C CHECK IF THIS IS A PREPBUFR FILE -C -------------------------------- - - R03O29 = 99 -c#V#V#dak - future -cdak IF(SUBSET.EQ.'ADPUPA') R03O29 = PRPUPA(LUNIT,OBS) -caaaaadak - future - IF(R03O29.NE.99) RETURN - R03O29 = 0 - - CALL S05O29 - -C VERTICAL SIGNIFICANCE DESCRIPTOR TO ASSIGN ON29 CATEGORY -C -------------------------------------------------------- - -C NOTE: MNEMONIC "VSIG" 008001 IS DEFINED AS VERTICAL SOUNDING -C SIGNIFICANCE -- CODE TABLE FOLLOWS: -C 64 Surface -C processed as ON29 category 2 and/or 3 and/or 4 -C 32 Standard (mandatory) level -C processed as ON29 category 1 -C 16 Tropopause level -C processed as ON29 category 5 -C 8 Maximum wind level -C processed as ON29 category 3 or 4 -C 4 Significant level, temperature -C processed as ON29 category 2 -C 2 Significant level, wind -C processed as ON29 category 3 or 4 -C 1 ??????????????????????? -C processed as ON29 category 6 -C -C anything else - the level is not processed - - CALL UFBINT(LUNIT,VSG_8,1,255,NLEV,'VSIG');VSG=VSG_8 - -C PUT THE HEADER INFORMATION INTO ON29 FORMAT -C ------------------------------------------- - - CALL UFBINT(LUNIT,HDR_8,12, 1,IRET,HDSTR);HDR(2:)=HDR_8(2:) - IF(HDR(5).GE.BMISS) HDR(5) = 0 - CALL UFBINT(LUNIT,RID_8,1,1,IRET,'RPID') - IF(IRET.NE.1) SID = 'MISSING ' -cppppp-ID - iprint = 0 -c if(sid.eq.'59758 ') iprint = 1 -c if(sid.eq.'61094 ') iprint = 1 -c if(sid.eq.'62414 ') iprint = 1 -c if(sid.eq.'59362 ') iprint = 1 -c if(sid.eq.'57957 ') iprint = 1 -c if(sid.eq.'74794 ') iprint = 1 -c if(sid.eq.'74389 ') iprint = 1 -c if(sid.eq.'96801A ') iprint = 1 - if(iprint.eq.1) - $ print'(" @@@ START DIAGNOSTIC PRINTOUT FOR ID ",A)', sid -cppppp-ID - - IRECCO = 0 - CALL UFBINT(LUNIT,RPMSL_8,1, 1,IRET,'PMSL');RPMSL=RPMSL_8 - IF(SUBSET.EQ.'NC004005') THEN - CALL UFBINT(LUNIT,RGP10_8,1,255,NLEV,'GP10');RGP10=RGP10_8 - CALL UFBINT(LUNIT,RPSAL_8,1,1,IRET,'PSAL');RPSAL=RPSAL_8 - IF(NINT(VSG(1)).EQ.32.AND.RPMSL.GE.BMISS.AND. - $ MAX(RGP10(1),RPSAL).LT.BMISS) THEN -cppppp -cdak print'(" ~~IW3UNP29/R03O29: ID ",A," is a Cat. 1 type ", -cdak $ "Flight-level RECCO")', sid -cppppp - IRECCO = 1 - ELSE IF(MIN(VSG(1),RPMSL,RGP10(1)).GE.BMISS.AND.RPSAL.LT. - $ BMISS) - $ THEN -cppppp -cdak print'(" ~~IW3UNP29/R03O29: ID ",A," is a Cat. 6 type ", -cdak $ "Flight-level RECCO (but reformatted into cat. 2/3)")', sid -cppppp - IRECCO = 6 - ELSE IF(MIN(VSG(1),RGP10(1)).GE.BMISS.AND.MAX(RPMSL,RPSAL) - $ .LT.BMISS) THEN -cppppp -cdak print'(" ~~IW3UNP29/R03O29: ID ",A," is a Cat. 2/3 type ", -cdak $ "Flight-level RECCO with valid PMSL")', sid -cppppp - IRECCO = 23 - ELSE -cppppp - print'(" ~~IW3UNP29/R03O29: ID ",A," is currently an ", - $ "unknown type of Flight-level RECCO - VSIG =",G0, - $ "; PMSL =",G0,"; GP10 =",G0," -- SKIP IT for now")', - $ sid,VSG(1),RPMSL,RGP10(1) - R03O29 = -9999 - KSKUPA =KSKUPA + 1 - RETURN -cppppp - END IF - END IF - - XOB = HDR(2) - YOB = HDR(3) - RHR = BMISS - IF(HDR(4).LT.BMISS) RHR = NINT(HDR(4))+NINT(HDR(5))/60. - RCH = BMISS - RSV = '999 ' - ELV = HDR(6) - IF(IRECCO.GT.0) THEN - RPSAL = RPSAL + SIGN(0.0000001,RPSAL) - ELV = RPSAL - END IF - - CALL UFBINT(LUNIT,RAT_8, 1,255,NLEV,'RATP');RAT=RAT_8 - ITP = MIN(99,NINT(RAT(1))) - RTP = E33O29(SUBSET,SID) - IF(ELV.GE.BMISS) THEN -cppppp - print'(" IW3UNP29/R03O29: ID ",A," has a missing elev, so ", - $ "elevation set to ZERO")', sid -cppppp - IF((RTP.GT.20.AND.RTP.LT.24).OR.SUBSET.EQ.'NC002004') ELV = 0 - END IF -cdak if(sid(5:5).eq.' ') print'(A)', sid - IF(L02O29(SID).AND.SID(5:5).EQ.' ') SID = '0'//SID - RSV2 = ' ' - CALL S01O29(SID,XOB,YOB,RHR,RCH,RSV,RSV2,ELV,ITP,RTP) - -C PUT THE LEVEL DATA INTO ON29 UNITS -C ---------------------------------- - - CALL UFBINT(LUNIT,ARR_8,10,255,NLEV,LVSTR);ARR=ARR_8 - - PWMIN = 999999. - JLV = 2 - IF(IRECCO.EQ.6) JLV = 1 - IF(IRECCO.GT.0.AND.NLEV.EQ.1) THEN - VSG(JLV) = 4 - VSG(JLV+1) = 2 - QOB(JLV) = E07O29(ARR(2,1),ARR(3,1)) - TOB(JLV) = E06O29(ARR(3,1)) - ARR(2,1) = BMISS - ARR(3,1) = BMISS - DOB(JLV+1) = E04O29(ARR(6,1),ARR(7,1)) - SOB(JLV+1) = E05O29(ARR(6,1),ARR(7,1)) - IF(NINT(DOB(JLV+1)).EQ.0.AND.NINT(SOB(JLV+1)).GT.0) - $ DOB(JLV+1) = 360. - IF(NINT(DOB(JLV+1)).EQ.360.AND.NINT(SOB(JLV+1)).EQ.0) - $ DOB(JLV+1) = 0. - ARR(6,1) = BMISS - ARR(7,1) = BMISS - IF(IRECCO.EQ.23) THEN - VSG(1) = 64 - ARR(1,1) = RPMSL - END IF - END IF - - IF(IRECCO.EQ.6) GO TO 4523 - - DO L=1,NLEV - POB(L) = E01O29(ARR(1,L)) - IF(NINT(ARR(1,L)).LE.0) THEN - POB(L) = BMISS -cppppp - print'(" ~~@@IW3UNP29/R03O29: ID ",A," has a ZERO or ", - $ "negative reported pressure that is reset to missing")', - $ sid -cppppp - END IF - QOB(L) = E07O29(ARR(2,L),ARR(3,L)) - TOB(L) = E06O29(ARR(3,L)) - ZOB(L) = MIN(E08O29(ARR(4,L)),E08O29(ARR(5,L))) -cppppp - if(iprint.eq.1) then - if(irecco.gt.0) print'(" At lvl=",I0,"; orig. ZOB = ",G0)', - $ L,zob(L) - end if -cppppp - IF(IRECCO.EQ.1) THEN - IF(MOD(NINT(ZOB(L)),10).NE.0) ZOB(L) = INT(ZOB(L)/10.) * 10 - ZOB(L) = NINT(ZOB(L)) - ELSEIF(IRECCO.EQ.23) THEN - ZOB(L) = 0 - END IF - DOB(L) = E04O29(ARR(6,L),ARR(7,L)) - SOB(L) = E05O29(ARR(6,L),ARR(7,L)) - IF(NINT(DOB(L)).EQ.0.AND.NINT(SOB(L)).GT.0) DOB(L) = 360. - IF(NINT(DOB(L)).EQ.360.AND.NINT(SOB(L)).EQ.0) DOB(L) = 0. -cppppp - if(iprint.eq.1) then - print'(" At lvl=",I0,"; VSG=",G0,"; POB = ",G0,"; QOB = ",G0, - $ "; TOB = ",G0,"; ZOB = ",G0,"; DOB = ",G0,"; final SOB ", - $ "(kts) = ",G0,"; origl SOB (mps) = ",G0)', - $ L,vsg(L),pob(L),qob(L),tob(L),zob(L),dob(L),sob(L),arr(7,L) - end if -cppppp - IF(IRECCO.EQ.0.AND.MAX(POB(L),DOB(L),SOB(L)).LT.BMISS) - $ PWMIN=MIN(PWMIN,POB(L)) - ENDDO - - 4523 CONTINUE - - MLEV = NLEV - - CALL UFBINT(LUNIT,ARR_8,10,255,NLEV,QMSTR);ARR=ARR_8 - - IF(IRECCO.GT.0.AND.MLEV.EQ.1) THEN - POB1 = BMISS - IF(POB(1).LT.BMISS) POB1 = POB(1) * 0.1 - TOB1 = BMISS - IF(TOB(JLV).LT.BMISS) TOB1 = (TOB(JLV) * 0.1) + 273.15 - RPS1 = RPSAL - ZOB1 = ZOB(1) - TQM1 = ARR(3,1) - POB(JLV)=NINT(E37O29(POB1,TOB1,RPS1,ZOB1,TQM1)) * 10 - POB(JLV+1) = POB(JLV) -cppppp - if(iprint.eq.1) then - do L=JLV,JLV+1 - print'(" At lvl=",I0,"; VSG=",G0,"; POB = ",G0,"; QOB = ", - $ G0,"; TOB = ",G0,"; ZOB = ",G0,"; DOB = ",G0,"; SOB = ", - $ G0)', L,vsg(L),pob(L),qob(L),tob(L),zob(L),dob(L),sob(L) - enddo - end if -cppppp - END IF - - IF(IRECCO.GT.0.AND.NLEV.EQ.1) THEN - PQM(JLV) = 'E' - PQM(JLV+1) = 'E' - TQM(JLV) = E35O29(ARR(2,1)) - ARR(2,1) = BMISS - QQM(JLV) = E35O29(ARR(3,1)) - ARR(3,1) = BMISS - ARR(4,1) = 3 - WQM(JLV+1) = E35O29(ARR(5,1)) - ARR(5,1) = BMISS - END IF - - IF(IRECCO.EQ.6) GO TO 4524 - - DO L=1,NLEV - PQM(L) = E35O29(ARR(1,L)) - TQM(L) = E35O29(ARR(2,L)) - QQM(L) = E35O29(ARR(3,L)) - ZQM(L) = E35O29(ARR(4,L)) - WQM(L) = E35O29(ARR(5,L)) - ENDDO - - 4524 CONTINUE - - IF(IRECCO.GT.0.AND.NLEV.EQ.1) NLEV = JLV + 1 - -C SURFACE DATA MUST GO FIRST -C -------------------------- - - CALL S02O29(2,0,*9999) - CALL S02O29(3,0,*9999) - CALL S02O29(4,0,*9999) - - INDX2 = 0 - INDX8 = 0 - INDX16 = 0 - P2 = BMISS - P8 = BMISS - P16 = BMISS - - DO L=1,NLEV - IF(NINT(VSG(L)).EQ.64) THEN -cppppp - if(iprint.eq.1) then - print'(" Lvl=",L," is a surface level")' - end if - if(iprint.eq.1.and.POB(L).LT.BMISS.AND.(TOB(L).LT.BMISS.OR.IRECCO - $ .EQ.23)) then - print'(" --> valid cat. 2 sfc. lvl ")' - end if -cppppp - IF(POB(L).LT.BMISS.AND.(TOB(L).LT.BMISS.OR.IRECCO.EQ.23)) - $ CALL SE01O29(2,L) -cppppp - if(iprint.eq.1.and.POB(L).LT.BMISS.AND.(DOB(L).LT.BMISS.OR.IRECCO - $ .EQ.23)) then - print'(" --> valid cat. 3 sfc. lvl ")' - end if -cppppp - IF(POB(L).LT.BMISS.AND.(DOB(L).LT.BMISS.OR.IRECCO.EQ.23)) - $ CALL SE01O29(3,L) - IF(ZOB(L).LT.BMISS.AND.DOB(L).LT.BMISS) THEN -cppppp - if(iprint.eq.1) print'(" --> valid cat. 4 sfc. lvl ")' -cppppp - -C CAT. 4 HEIGHT DOES NOT PASS ON A KEEP, PURGE, OR REJECT LIST Q.M. -C ----------------------------------------------------------------- - - ZQM(L) = ' ' - CALL SE01O29(4,L) - END IF - VSG(L) = 0 - ELSE IF(NINT(VSG(L)).EQ.2) THEN - P2(L) = POB(L) - INDX2 = L - IF(INDX8.GT.0) THEN - DO II = 1,INDX8 - IF(POB(L).EQ.P8(II).AND.POB(L).LT.BMISS) THEN -cppppp - if(iprint.eq.1) then - print'(" ## This cat. 3 level, on lvl ",I0, - $ " will have already been processed as a cat. 3 ", - $ "MAX wind lvl (on lvl ",I0,") - skip this Cat. ", - $ "3 lvl")', L,II - end if -cppppp - IF(MAX(SOB(II),DOB(II)).GE.BMISS) THEN - SOB(II) = SOB(L) - DOB(II) = DOB(L) -cppppp - if(iprint.eq.1) then - print'(" ...... also on lvl ",I0," - transfer", - $ " wind data to dupl. MAX wind lvl because its ", - $ "missing there")', L - end if -cppppp - END IF - VSG(L) = 0 - GO TO 7732 - END IF - ENDDO - END IF - ELSE IF(NINT(VSG(L)).EQ.8) THEN - P8(L) = POB(L) - INDX8 = L - IF(INDX2.GT.0) THEN - DO II = 1,INDX2 - IF(POB(L).EQ.P2(II).AND.POB(L).LT.BMISS) THEN -cppppp - if(iprint.eq.1) then - print'(" ## This MAX wind level, on lvl ",I0, - $ " will have already been processed as a cat. 3 ", - $ "lvl (on lvl ",I0,") - skip this MAX wind lvl ", - $ "but set"/6X,"cat. 3 lvl PQM to ""W""")', L,II - end if -cppppp - PQM(II) = 'W' - IF(POB(L).EQ.PWMIN) PQM(II) = 'X' - IF(MAX(SOB(II),DOB(II)).GE.BMISS) THEN - SOB(II) = SOB(L) - DOB(II) = DOB(L) -cppppp - if(iprint.eq.1) then - print'(" ...... also on lvl ",I0," - transfer", - $ " wind data to dupl. cat. 3 lvl because its ", - $ "missing there")', L - end if -cppppp - END IF - VSG(L) = 0 - GO TO 7732 - END IF - ENDDO - END IF - IF(INDX8-1.GT.0) THEN - DO II = 1,INDX8-1 - IF(POB(L).EQ.P8(II).AND.POB(L).LT.BMISS) THEN -cppppp - if(iprint.eq.1) then - print'(" ## This cat. 3 MAX wind lvl, on lvl ",I0, - $ " will have already been processed as a cat. 3 ", - $ "MAX wind lvl (on lvl ",I0,") - skip this Cat. ", - $ "3 MAX wind lvl")', L,II - end if -cppppp - IF(MAX(SOB(II),DOB(II)).GE.BMISS) THEN - SOB(II) = SOB(L) - DOB(II) = DOB(L) -cppppp - if(iprint.eq.1) then - print'(" ...... also on lvl ",I0," - transfer", - $ " wind data to dupl. MAX wind lvl because its ", - $ "missing there")', L - end if -cppppp - END IF - VSG(L) = 0 - GO TO 7732 - END IF - ENDDO - END IF - ELSE IF(NINT(VSG(L)).EQ.16) THEN - INDX16 = INDX16 + 1 - P16(INDX16) = POB(L) - END IF - 7732 CONTINUE - ENDDO - -C TAKE CARE OF 925 MB NEXT -C ------------------------ - - DO L=1,NLEV - IF(NINT(VSG(L)).EQ.32 .AND. NINT(POB(L)).EQ.9250) THEN - CF8(L) = 925 - OB8(L) = ZOB(L) - Q81(L) = ' ' - Q82(L) = ' ' - IF(TOB(L).LT.BMISS) CALL S02O29(2,L,*9999) - IF(DOB(L).LT.BMISS) CALL S02O29(3,L,*9999) - IF(OB8(L).LT.BMISS) CALL S02O29(8,L,*9999) - VSG(L) = 0 - END IF - ENDDO - -C REST OF THE DATA -C ---------------- - - Z100 = 16000 - DO L=1,NLEV - IF(NINT(VSG(L)).EQ.32) THEN - IF(MIN(DOB(L),ZOB(L),TOB(L)).GE.BMISS) THEN -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG=32 & DOB,ZOB,TOB all ", - $ "missing --> this level not processed")', L - end if - VSG(L) = 0 - ELSE IF(MIN(ZOB(L),TOB(L)).LT.BMISS) THEN -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG=32 & one or both of ", - $ "ZOB,TOB non-missing --> valid cat. 1 lvl")', L - end if -cppppp - CALL S02O29(1,L,*9999) - IF(NINT(POB(L)).EQ.1000.AND.ZOB(L).LT.BMISS) Z100 = ZOB(L) - VSG(L) = 0 - END IF - END IF - ENDDO - DO L=1,NLEV - IF(NINT(VSG(L)).EQ.32) THEN - IF(DOB(L).LT.BMISS.AND.MIN(ZOB(L),TOB(L)).GE.BMISS) THEN - LL = I04O29(POB(L)*.1) - IF(LL.EQ.999999) THEN -cppppp - print'(" ~~IW3UNP29/R03O29: ID ",A," has VSG=32 for ", - $ "lvl ",I0," but pressure not mand.!! --> this level ", - $ "not processed")', sid,L -cppppp - ELSE IF(MIN(RCATS(1,LL,1),RCATS(2,LL,1)).LT.99999.) THEN - IF(RCATS(4,LL,1).GE.99998.) THEN -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG=32 & ZOB,TOB ", - $ "both missing while DOB non-missing BUT one or ", - $ "both of Z, T non-missing while wind missing ", - $ "in"/7X,"earlier cat. 1 processing of this ",G0, - $ "mb level --> valid cat. 1 lvl")', L,POB(L)*.1 - end if -cppppp - CALL S02O29(1,L,*9999) - ELSE -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG=32 & ZOB,TOB ", - $ "both missing while DOB non-missing BUT one or ", - $ "both of Z, T non-missing while wind non-missing", - $ " in"/6X,"earlier cat. 1 processing of this ",G0, - $ "mb level --> valid cat. 3 lvl")', L,POB(L)*.1 - end if -cppppp - CALL S02O29(3,L,*9999) - END IF - ELSE -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG=32 & ZOB,TOB both ", - $ "missing while DOB non-missing AND both Z, T ", - $ "missing on"/7X,"this ",G0,"mb level in cat. 1 --> ", - $ "valid cat. 3 lvl")', L,POB(L)*.1 - end if -cppppp - CALL S02O29(3,L,*9999) - END IF - ELSE -cppppp - print'(" ~~IW3UNP29/R03O29: ID ",A," has VSG=32 for lvl ", - $ I0," & should never come here!! - by default output", - $ " as cat. 1 lvl")', sid,L -cppppp - CALL S02O29(1,L,*9999) - END IF - VSG(L) = 0 - END IF - ENDDO - - DO L=1,NLEV - IF(NINT(VSG(L)).EQ. 4) THEN -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG= 4 --> valid cat. 2 ", - $ "lvl")', L - end if -cppppp - IF(INDX16.GT.0) THEN - DO II = 1,INDX16 - IF(POB(L).EQ.P16(II).AND.POB(L).LT.BMISS) THEN -cppppp - if(iprint.eq.1) then - print'(" ## This cat. 2 level, on lvl ",I0," is", - $ " also the tropopause level, as its pressure ", - $ "matches that of trop. lvl no. ",I0," - ", - $ "set this cat. 2"/5X,"lvl PQM to ""T""")', L,II - end if -cppppp - PQM(L) = 'T' - GO TO 7738 - END IF - ENDDO - END IF - 7738 CONTINUE - CALL S02O29(2,L,*9999) - VSG(L) = 0 - ELSEIF(NINT(VSG(L)).EQ.16) THEN -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG=16 --> valid cat. 3/5 ", - $ "lvl")', L - end if -cppppp - PQML = PQM(L) - IF(MIN(SOB(L),DOB(L)).LT.BMISS) CALL S02O29(3,L,*9999) - PQM(L) = PQML - CALL S02O29(5,L,*9999) - VSG(L) = 0 - ELSEIF(NINT(VSG(L)).EQ. 1) THEN -cppppp - print'(" ~~IW3UNP29/R03O29: HERE IS A VSG =1, SET TO CAT.6, ", - $ "AT ID ",A,"; SHOULD NEVER HAPPEN!!")', SID -cppppp - CALL S02O29(6,L,*9999) - VSG(L) = 0 - ELSEIF(NINT(VSG(L)).EQ. 2 .AND. POB(L).LT.BMISS) THEN - IF(MAX(SOB(L),DOB(L)).LT.BMISS) THEN -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG= 2 & POB .ne. missing ", - $ "--> valid cat. 3 lvl (expect that ZOB is missing)")', L - end if -cppppp - CALL S02O29(3,L,*9999) - ELSE -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG= 2 & POB .ne. missing ", - $ "--> Cat. 3 level not processed - wind is missing")', L - end if -cppppp - END IF - VSG(L) = 0 - ELSEIF(NINT(VSG(L)).EQ. 2 .AND. ZOB(L).LT.BMISS) THEN - IF(MAX(SOB(L),DOB(L)).LT.BMISS) THEN - -C CERTAIN U.S. WINDS-BY-HEIGHT ARE CORRECTED TO ON29 CONVENTION -C ------------------------------------------------------------- - - IF(SID(1:2).EQ.'70'.OR.SID(1:2).EQ.'71'.OR.SID(1:2).EQ.'72' - $ .OR.SID(1:2).EQ.'74') ZOB(L) = E34O29(ZOB(L),Z100) -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG= 2 & ZOB .ne. missing ", - $ "--> valid cat. 4 lvl (POB must always be missing)")', L - if(sid(1:2).eq.'70'.or.sid(1:2).eq.'71'.or.sid(1:2).eq.'72' - $ .or.sid(1:2).eq.'74') print'(" .... ZOB at this ", - $ "U.S. site adjusted to ",G0)', zob(L) - end if -cppppp - -C CAT. 4 HEIGHT DOES NOT PASS ON A KEEP, PURGE, OR REJECT LIST Q.M. -C ----------------------------------------------------------------- - - ZQM(L) = ' ' - - CALL S02O29(4,L,*9999) - ELSE -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG= 2 & ZOB .ne. missing ", - $ "--> Cat. 4 level not processed - wind is missing")', L - end if -cppppp - END IF - VSG(L) = 0 - ELSEIF(NINT(VSG(L)).EQ. 8 .AND. POB(L).LT.BMISS) THEN -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG= 8 & POB .ne. missing ", - $ "--> valid cat. 3 lvl (expect that ZOB is missing)")', L - end if -cppppp - CALL S02O29(3,L,*9999) - VSG(L) = 0 - ELSEIF(NINT(VSG(L)).EQ. 8 .AND. ZOB(L).LT.BMISS) THEN - IF(MAX(SOB(L),DOB(L)).LT.BMISS) THEN - -C CERTAIN U.S. WINDS-BY-HEIGHT ARE CORRECTED TO ON29 CONVENTION -C ------------------------------------------------------------- - - IF(SID(1:2).EQ.'70'.OR.SID(1:2).EQ.'71'.OR.SID(1:2).EQ.'72' - $ .OR.SID(1:2).EQ.'74') ZOB(L) = E34O29(ZOB(L),Z100) -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG= 8 & ZOB .ne. missing ", - $ "--> valid cat. 4 lvl (POB must always be missing)")', L - if(sid(1:2).eq.'70'.or.sid(1:2).eq.'71'.or.sid(1:2).eq.'72' - $ .or.sid(1:2).eq.'74') print'(" .... ZOB at this ", - $ "U.S. site adjusted to ",G0)', zob(L) - end if -cppppp - -C CAT. 4 HEIGHT DOES NOT PASS ON A KEEP, PURGE, OR REJECT LIST Q.M. -C ----------------------------------------------------------------- - - ZQM(L) = ' ' - - CALL S02O29(4,L,*9999) - ELSE -cppppp - if(iprint.eq.1) then - print'(" ==> For lvl ",I0,"; VSG= 8 & ZOB .ne. missing ", - $ "--> Cat. 4 level not processed - wind is missing")', L - end if -cppppp - END IF - VSG(L) = 0 - END IF - ENDDO - -C CHECK FOR LEVELS WHICH GOT LEFT OUT -C ----------------------------------- - - DO L=1,NLEV - IF(NINT(VSG(L)).GT.0) THEN - PRINT 887, L,SID,NINT(VSG(L)) - 887 FORMAT(' ##IW3UNP29/R03O29 - ~~ON LVL',I4,' OF ID ',A8,', A ', - $ 'VERTICAL SIGNIFICANCE OF',I3,' WAS NOT SUPPORTED - LEAVE ', - $ 'THIS LEVEL OUT OF THE PROCESSING') - print'(" ..... at lvl=",I0,"; POB = ",G0,"; QOB = ",G0, - $ "; TOB = ",G0,"; ZOB = ",G0,"; DOB = ",G0,";"/19X,"SOB = ", - $ G0)', pob(L),qob(L),tob(L),zob(L),dob(L),sob(L) - END IF - ENDDO - -C CLOUD DATA GOES INTO CATEGORY 07 -C -------------------------------- - - CALL UFBINT(LUNIT,ARR_8,10,255,NLEV,'HOCB CLAM QMCA HBLCS') - ARR=ARR_8 - DO L=1,NLEV - IF(ARR(1,L).LT.BMISS/2.) THEN - ! Prior to 3/2002 HBLCS was not available, this will - ! always be tested first because it is more precise - ! in theory but will now be missing after 3/2002 - IF(ELV+ARR(1,L).GE.BMISS/2.) THEN - CLP(L) = BMISS - ELSE IF(ELV+ARR(1,L).LE.11000) THEN - CLP(L) = (PRS1(ELV+ARR(1,L))*10.) + 0.001 - ELSE - CLP(L) = (PRS2(ELV+ARR(1,L))*10.) + 0.001 - END IF - ELSE - ! Effective 3/2002 only this will be available - IF(NINT(ARR(4,L)).GE.10) THEN - CLP(L) = BMISS - ELSE - IF(ELV+IHBLCS(NINT(ARR(4,L))).GE.BMISS/2.) THEN - CLP(L) = BMISS - ELSE IF(ELV+IHBLCS(NINT(ARR(4,L))).LE.11000) THEN - CLP(L) = (PRS1(ELV+IHBLCS(NINT(ARR(4,L))))*10.) +0.001 - ELSE - CLP(L) = (PRS2(ELV+IHBLCS(NINT(ARR(4,L))))*10.) +0.001 - END IF - END IF - END IF - CLA(L) = E13O29(ARR(2,L)) - QCP(L) = ' ' - QCA(L) = E35O29(ARR(3,L)) - IF(CLP(L).LT.BMISS .OR. CLA(L).LT.BMISS) CALL S02O29(7,L,*9999) - ENDDO - -C ----------------------------------------------------- -C MISC DATA GOES INTO CATEGORY 08 -C ----------------------------------------------------- -C CODE FIGURE 104 - RELEASE TIME IN .01*HR -C CODE FIGURE 105 - RECEIPT TIME IN .01*HR -C CODE FIGURE 106 - RADIOSONDE INSTR. TYPE, -C SOLAR/IR CORRECTION INDICATOR, -C TRACKING TECH/STATUS OF SYSTEM USED -C CODE FIGURE 925 - HEIGHT OF 925 LEVEL -C ----------------------------------------------------- - - CALL UFBINT(LUNIT,RCT_8, 5,255,NRCT,RCSTR);RCT=RCT_8 - -C NOTE: MNEMONIC "RCTS" 008202 IS A LOCAL DESCRIPTOR DEFINED AS -C RECEIPT TIME SIGNIFICANCE -- CODE TABLE FOLLOWS: -C 0 General decoder receipt time -C 1 NCEP receipt time -C 2 OSO receipt time -C 3 ARINC ground station receipt time -C 4 Radiosonde TEMP AA part receipt time -C 5 Radiosonde TEMP BB part receipt time -C 6 Radiosonde TEMP CC part receipt time -C 7 Radiosonde TEMP DD part receipt time -C 8 Radiosonde PILOT AA part receipt time -C 9 Radiosonde PILOT BB part receipt time -C 10 Radiosonde PILOT CC part receipt time -C 11 Radiosonde PILOT DD part receipt time -C 12-62 Reserved for future use -C 63 Missing - - DO L=1,NRCT - CF8(L) = 105 - OB8(L) = NINT((NINT(RCT(1,L))+NINT(RCT(2,L))/60.) * 100.) - IF(IRECCO.GT.0.AND.NINT(RCT(3,L)).EQ.0) RCT(3,L) = 9 - Q81(L) = E36O29(NINT(RCT(3,L))) - Q82(L) = ' ' - CALL S02O29(8,L,*9999) - ENDDO - - CALL UFBINT(LUNIT,RMORE_8,4,1,NRMORE,'SIRC TTSS UALNHR UALNMN') - RMORE=RMORE_8 - IF(MAX(RMORE(3),RMORE(4)).LT.BMISS) THEN - CF8(1) = 104 - OB8(1) = NINT((RMORE(3)+RMORE(4)/60.) * 100.) - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - IF(NINT(RAT(1)).LT.100) THEN - CF8(1) = 106 - ISIR = 9 - IF(NINT(RMORE(1)).LT.9) ISIR = NINT(RMORE(1)) - ITEC = 99 - IF(NINT(RMORE(2)).LT.99) ITEC = NINT(RMORE(2)) - OB8(1) = (ISIR * 10000) + (NINT(RAT(1)) * 100) + ITEC - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - -C PUT THE UNPACKED ON29 REPORT INTO OBS -C ------------------------------------- - - CALL S03O29(OBS,SUBSET,*9999,*9998) - - RETURN - 9999 CONTINUE - R03O29 = 999 - RETURN - 9998 CONTINUE - print'(" IW3UNP29/R03O29: RPT with ID= ",A," TOSSED - ZERO ", - $ "CAT.1-6,51,52 LVLS")', SID - R03O29 = -9999 - KSKUPA =KSKUPA + 1 - RETURN - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION R04O29(LUNIT,OBS) -C ---> formerly FUNCTION SURFCE - - COMMON/IO29EE/POB(255),QOB(255),TOB(255),ZOB(255),DOB(255), - $ SOB(255),VSG(255),CLP(255),CLA(255),OB8(255), - $ CF8(255) - COMMON/IO29FF/PQM(255),QQM(255),TQM(255),ZQM(255),WQM(255), - $ QCP(255),QCA(255),Q81(255),Q82(255) - COMMON/IO29GG/PSL,STP,SDR,SSP,STM,DPD,TMX,TMI,HVZ,PRW,PW1,CCN,CHN, - $ CTL,CTM,CTH,HCB,CPT,APT,PC6,SND,P24,DOP,POW,HOW,SWD, - $ SWP,SWH,SST,SPG,SPD,SHC,SAS,WES - COMMON/IO29HH/PSQ,SPQ,SWQ,STQ,DDQ - COMMON/IO29CC/SUBSET,IDAT10 - COMMON/IO29BB/KNDX,KSKACF(8),KSKUPA,KSKSFC,KSKSAT,KSKSMI - COMMON/IO29LL/BMISS - - CHARACTER*80 HDSTR,RCSTR - CHARACTER*8 SUBSET,SID,E35O29,RSV,RSV2 - CHARACTER*1 PQM,QQM,TQM,ZQM,WQM,QCP,QCA,Q81,Q82,PSQ,SPQ,SWQ,STQ, - $ DDQ - REAL(8) RID_8,UFBINT_8,BMISS - REAL(8) HDR_8(20),RCT_8(5,255),RRSV_8(3),CLDS_8(4,255), - $ TMXMNM_8(4,255) - INTEGER ITIWM(0:15),IHBLCS(0:9) - DIMENSION OBS(*),HDR(20),RCT(5,255),RRSV(3),CLDS(4,255),JTH(0:9), - $ JTL(0:9),LTL(0:9),TMXMNM(4,255) - EQUIVALENCE (RID_8,SID) - - SAVE - - DATA HDSTR/'RPID CLON CLAT HOUR MINU SELV AUTO '/ - DATA RCSTR/'RCHR RCMI RCTS '/ - - DATA JTH/0,1,2,3,4,5,6,8,7,9/,JTL/0,1,5,8,7,2,3,4,6,9/ - DATA LTL/0,1,5,6,7,2,8,4,3,9/ - DATA ITIWM/0,3*7,3,3*7,1,3*7,4,3*7/ - DATA IHBLCS/25,75,150,250,450,800,1250,1750,2250,2500/ - -C CHECK IF THIS IS A PREPBUFR FILE -C -------------------------------- - - R04O29 = 99 -c#V#V#dak - future -cdak IF(SUBSET.EQ.'ADPSFC') R04O29 = PRPSFC(LUNIT,OBS) -cdak IF(SUBSET.EQ.'SFCSHP') R04O29 = PRPSFC(LUNIT,OBS) -cdak IF(SUBSET.EQ.'SFCBOG') R04O29 = PRPSFC(LUNIT,OBS) -caaaaadak - future - IF(R04O29.NE.99) RETURN - R04O29 = 0 - - CALL S05O29 - -C PUT THE HEADER INFORMATION INTO ON29 FORMAT -C ------------------------------------------- - - CALL UFBINT(LUNIT,HDR_8,20, 1,IRET,HDSTR);HDR(2:)=HDR_8(2:) - CALL UFBINT(LUNIT,RCT_8, 5,255,NRCT,RCSTR);RCT=RCT_8 - IF(HDR(5).GE.BMISS) HDR(5) = 0 - RCTIM = NINT(RCT(1,1))+NINT(RCT(2,1))/60. - RID_8 = HDR_8(1) - XOB = HDR(2) - YOB = HDR(3) - RHR = BMISS - IF(HDR(4).LT.BMISS) RHR = NINT(HDR(4))+NINT(HDR(5))/60. - RCH = RCTIM - ELV = HDR(6) - -C I1 DEFINES SYNOPTIC FORMAT FLAG (SUBSET NC000001, NC000009) -C I1 DEFINES AUTOMATED STATION TYPE (SUBSET NC000003-NC000008,NC000010) -C I2 DEFINES CONVERTED HOURLY FLAG (SUBSET NC000xxx) -C I2 DEFINES SHIP LOCATION FLAG (SUBSET NC001xxx) (WHERE xxx != 006) - - I1 = 9 - I2 = 9 - IF(SUBSET(1:5).EQ.'NC000') THEN - IF(SUBSET(6:8).EQ.'001'.OR.SUBSET(6:8).EQ.'009') THEN - I1 = 1 - IF(SUBSET(6:8).EQ.'009') I2 = 1 - ELSE IF(SUBSET(6:8).NE.'002') THEN - IF(HDR(7).LT.15) THEN - IF(HDR(7).GT.0.AND.HDR(7).LT.5) THEN - I1 = 2 - ELSE IF(HDR(7).EQ.8) THEN - I1 = 3 - ELSE - I1 = 4 - END IF - END IF - END IF - END IF - ITP = (10 * I1) + I2 - RTP = E33O29(SUBSET,SID) - -C THE 25'TH (RESERVE) CHARACTER IS INDICATOR FOR PRECIP. (INCL./EXCL.) -C THE 26'TH (RESERVE) CHARACTER IS INDICATOR FOR W SPEED (SOURCE/UNITS) -C '0' - Wind speed estimated in m/s (uncertified instrument) -C '1' - Wind speed obtained from anemometer in m/s (certified -C instrument) -C '3' - Wind speed estimated in knots (uncertified instrument) -C '4' - Wind speed obtained from anemometer in knots (certified -C instrument) -C '7' - Missing -C THE 27'TH (RESERVE) CHARACTER IS INDICATOR FOR STN OPER./PAST WX DATA - - CALL UFBINT(LUNIT,UFBINT_8,1,1,NRSV,'INPC');RRSV(1)=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,NRSV,'TIWM');TIWM=UFBINT_8 - IF(TIWM.LT.BMISS) THEN ! Effective 3/2002 - RRSV(2) = 7 - IF(NINT(TIWM).LE.15) RRSV(2) = ITIWM(NINT(TIWM)) - ELSE ! Prior to 3/2002 - CALL UFBINT(LUNIT,UFBINT_8,1,1,NRSV,'SUWS');RRSV(2)=UFBINT_8 - END IF - CALL UFBINT(LUNIT,UFBINT_8,1,1,NRSV,'ITSO');RRSV(3)=UFBINT_8 - RSV = '999 ' - DO I=1,3 - IF(RRSV(I).LT.BMISS) WRITE(RSV(I:I),'(I1)') NINT(RRSV(I)) - ENDDO - -C READ THE CATEGORY 51 SURFACE DATA FROM BUFR -C ------------------------------------------- - - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'PMSL');PSL=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'PRES');STP=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'WDIR');SDR=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'WSPD');SSP=UFBINT_8 - WSPD1 = SSP - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TMDB');STM=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TMDP');DPD=UFBINT_8 - IF(SUBSET.NE.'NC000007') THEN - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'MXTM');TMX=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'MITM');TMI=UFBINT_8 - ELSE - TMX = BMISS - TMI = BMISS - END IF - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'QMPR');QSL=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'QMPR');QSP=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'QMWN');QMW=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'QMAT');QMT=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'QMDD');QMD=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'HOVI');HVZ=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'PRWE');PRW=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'PSW1');PW1=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'PSW2');PW2=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TOCC');CCN=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'CHPT');CPT=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'3HPC');APT=UFBINT_8 - IF(MAX(APT,CPT).GE.BMISS) THEN - APT = BMISS - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'24PC');APT24=UFBINT_8 - IF(APT24.LT.BMISS) THEN - APT = APT24 - CPT = BMISS - END IF - END IF - - -C READ THE CATEGORY 52 SURFACE DATA FROM BUFR -C ------------------------------------------- - - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TP06');PC6=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TOSD');SND=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TP24');P24=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TOPC');PTO=UFBINT_8 - IF(PTO.LT.BMISS) THEN - IF(PC6.GE.BMISS.AND.NINT(DOP).EQ. 6) PC6 = PTO -cppppp - IF(PC6.GE.BMISS.AND.NINT(DOP).EQ. 6) - $ print'(" ~~IW3UNP29/R04O29: PTO used for PC6 since latter ", - $ "missing & 6-hr DOP")' -cppppp - IF(P24.GE.BMISS.AND.NINT(DOP).EQ.24) P24 = PTO -cppppp - IF(P24.GE.BMISS.AND.NINT(DOP).EQ.24) - $ print'(" ~~IW3UNP29/R04O29: PTO used for P24 since latter ", - $ "missing & 24-hr DOP")' -cppppp - END IF - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'POWW');POW=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'HOWW');HOW=UFBINT_8 - IF(SUBSET(1:5).EQ.'NC001') THEN - IF(SUBSET(6:8).NE.'006') THEN - IF(MIN(POW,HOW).GE.BMISS) THEN - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'POWV');POW=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'HOWV');HOW=UFBINT_8 - END IF - ELSE -C PAOBS always have a missing elev, but we know they are at sea level - ELV = 0 - END IF - END IF - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'DOSW');SWD=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'POSW');SWP=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'HOSW');SWH=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'SST1');SST=UFBINT_8 - IF(SST.GE.BMISS) THEN - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'STMP');SST=UFBINT_8 - ENDIF - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'????');SPG=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'????');SPD=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TDMP');SHC=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'ASMP');SAS=UFBINT_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'????');WES=UFBINT_8 - I52FLG = 0 - IF(MIN(SND,P24,POW,HOW,SWD,SWP,SWH,SST,SPG,SPD,SHC,SAS,WES) - $ .GE.BMISS.AND.(PC6.EQ.0..OR.PC6.GE.BMISS)) I52FLG= 1 - -C SOME CLOUD DATA IS NEEDED FOR LOW, MIDDLE, AND HIGH CLOUDS IN CAT. 51 -C --------------------------------------------------------------------- - - CALL UFBINT(LUNIT,CLDS_8,4,255,NCLD,'VSSO CLAM CLTP HOCB') - CLDS=CLDS_8 - CTH = -9999. - CTM = -9999. - CTL = -9999. - CHH = BMISS - CHM = BMISS - CHL = BMISS - IF(NCLD.EQ.0) THEN - CCM = BMISS - CCL = BMISS - ELSE - CCM = 0. - CCL = 0. - DO L=1,NCLD - VSS = CLDS(1,L) - CAM = CLDS(2,L) - CTP = CLDS(3,L) - CHT = BMISS - IF(CLDS(4,L).LT.BMISS) THEN - ! Prior to 3/2002 HBLCS was not available, this will - ! always be tested first because it is more precise - ! and may still be available for some types after - ! 3/2002 - CHT = CLDS(4,L) - ELSE - ! Effective 3/2002 this will be available and can be - ! used for types where HOCB is not available - less - ! precise and only available on 1 level - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'HBLCS') - HBLCS=UFBINT_8 - IF(NINT(HBLCS).LT.10) CHT = IHBLCS(NINT(HBLCS)) - END IF - IF(CHT.LT.BMISS) CHT = CHT * 3.2808 - IF(NINT(VSS).EQ.0) THEN - IF(NINT(CTP).GT.9.AND.NINT(CTP).LT.20) THEN - ITH = MOD(NINT(CTP),10) - KTH = JTH(ITH) - CTH = MAX(KTH,NINT(CTH)) - CHH = MIN(CHT,CHH) - ELSE IF(NINT(CTP).LT.30) THEN - ITM = MOD(NINT(CTP),10) - CTM = MAX(ITM,NINT(CTM)) - IF(ITM.EQ.0) CAM = 0. - CCM = MAX(CAM,CCM) - CHM = MIN(CHT,CHM) - ELSE IF(NINT(CTP).LT.40) THEN - ITL = MOD(NINT(CTP),10) - KTL = JTL(ITL) - CTL = MAX(KTL,NINT(CTL)) - IF(ITL.EQ.0) CAM = 0. - CCL = MAX(CAM,CCL) - CHL = MIN(CHT,CHL) - ELSE IF(NINT(CTP).EQ.59) THEN - CTH = 10. - CTM = 10. - IF(CCM.EQ.0.) CCM = 15. - CTL = 10. - IF(CCL.EQ.0.) CCL = 15. - ELSE IF(NINT(CTP).EQ.60) THEN - CTH = 10. - ELSE IF(NINT(CTP).EQ.61) THEN - CTM = 10. - IF(CCM.EQ.0.) CCM = 15. - ELSE IF(NINT(CTP).EQ.62) THEN - CTL = 10. - IF(CCL.EQ.0.) CCL = 15. - END IF - END IF - ENDDO - END IF - IF(NINT(CTH).GT.-1.AND.NINT(CTH).LT.10) THEN - CTH = JTH(NINT(CTH)) - ELSE IF(NINT(CTH).NE.10) THEN - CTH = BMISS - END IF - IF(NINT(CTM).LT.0.OR.NINT(CTM).GT.10) THEN - CTM = BMISS - CCM = BMISS - END IF - IF(NINT(CTL).GT.-1.AND.NINT(CTL).LT.10) THEN - CTL = LTL(NINT(CTL)) - ELSE IF(NINT(CTL).NE.10) THEN - CTL = BMISS - CCL = BMISS - END IF - -C CALL FUNCTIONS TO TRANSFORM TO ON29/124 UNITS -C --------------------------------------------- - - PSL = E01O29(PSL) - STP = E01O29(STP) - SDR = E04O29(SDR,SSP) - SSP = E05O29(SDR,SSP) - IF(NINT(SDR).EQ.0) SDR = 360. - IF(SDR.GE.BMISS.AND.NINT(SSP).EQ.0) SDR = 360. - DPD = E07O29(DPD,STM) - STM = E06O29(STM) - TMX = E06O29(TMX) - TMI = E06O29(TMI) - - PSQ = E35O29(QSL) - SPQ = E35O29(QSP) - SWQ = E35O29(QMW) - STQ = E35O29(QMT) - DDQ = E35O29(QMD) - -C ADJUST QUIPS QUALITY MARKERS TO REFLECT UNPACKED ON29 CONVENTION - - IF(SUBSET(1:5).EQ.'NC001'.AND.PSQ.EQ.'C') STP = BMISS - IF(PSL.GE.BMISS) PSQ = ' ' - IF(STP.GE.BMISS) SPQ = ' ' - IF(MAX(SDR,SSP).GE.BMISS) SWQ = ' ' - IF(STM.GE.BMISS) STQ = ' ' - - IF(SUBSET(1:5).EQ.'NC000'.OR.SUBSET.EQ.'NC001004') THEN - HVZ = E09O29(HVZ) - ELSE - HVZ = E38O29(HVZ) - END IF - PRW = E10O29(PRW) - PW1 = E11O29(PW1) - PW2 = E11O29(PW2) - IF(DDQ.NE.'P'.AND.DDQ.NE.'H'.AND.DDQ.NE.'C') THEN - DDQ = ' ' - IPW2 = NINT(PW2) - IF(IPW2.GT.-1.AND.IPW2.LT.10) WRITE(DDQ,'(I1)') IPW2 - END IF - CCN = E12O29(CCN) - CHN = E14O29(CCL,CCM) - CTL = E15O29(CTL) - CTM = E15O29(CTM) - CTH = E15O29(CTH) - HCB = E18O29(CHL,CHM,CHH,CTL,CTM,CTH) - CPT = E19O29(CPT) - APT = E01O29(APT) - - PC6 = E20O29(PC6) - SND = E21O29(SND) - P24 = E20O29(P24) - DOP = E22O29(PC6) - POW = E23O29(POW) - HOW = E24O29(HOW) - SWD = E25O29(SWD) - SWP = E23O29(SWP) - SWH = E24O29(SWH) - SST = E06O29(SST) - SPG = E28O29(SPG) - SPD = E29O29(SPD) - SHC = E30O29(SHC) - SAS = E31O29(SAS) - WES = E32O29(WES) - -C MAKE THE UNPACKED ON29/124 REPORT INTO OBS -C ------------------------------------------ - - RSV2 = ' ' - CALL S01O29(SID,XOB,YOB,RHR,RCH,RSV,RSV2,ELV,ITP,RTP) - CALL S02O29(51,1,*9999) - IF(I52FLG.EQ.0) CALL S02O29(52,1,*9999) - -C ------------------------------------------------------------------ -C MISC DATA GOES INTO CATEGORY 08 -C ------------------------------------------------------------------ -C CODE FIGURE 020 - ALTIMETER SETTING IN 0.1*MB -C CODE FIGURE 081 - CALENDAR DAY MAXIMUM TEMPERATURE -C CODE FIGURE 082 - CALENDAR DAY MINIMUM TEMPERATURE -C CODE FIGURE 083 - SIX HOUR MAXIMUM TEMPERATURE -C CODE FIGURE 084 - SIX HOUR MINIMUM TEMPERATURE -C CODE FIGURE 085 - PRECIPITATION OVER PAST HOUR IN 0.01*INCHES -C CODE FIGURE 098 - DURATION OF SUNSHINE FOR CALENDAR DAY IN MINUTES -C CODE FIGURE 924 - WIND SPEED IN 0.01*M/S -C ------------------------------------------------------------------ - - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'ALSE');ALS=UFBINT_8 - IF(ALS.LT.BMISS) THEN - OB8(1) = E01O29(ALS) - CF8(1) = 20 - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - IF(SUBSET.EQ.'NC000007') THEN - CALL UFBINT(LUNIT,TMXMNM_8,4,255,NTXM, - $ '.DTHMXTM MXTM .DTHMITM MITM');TMXMNM=TMXMNM_8 - IF(NTXM.GT.0) THEN - DO I = 1,NTXM - DO J = 1,3,2 - IF(NINT(TMXMNM(J,I)).EQ.24) THEN - IF(TMXMNM(J+1,I).LT.BMISS) THEN - TMX = E06O29(TMXMNM(J+1,I)) - IF(TMX.LT.0) THEN - OB8(1) = 1000 + ABS(NINT(TMX)) - ELSE - OB8(1) = NINT(TMX) - END IF - CF8(1) = 81 + INT(J/2) - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - ELSE IF(NINT(TMXMNM(J,I)).EQ.6) THEN - IF(TMXMNM(J+1,I).LT.BMISS) THEN - TMX = E06O29(TMXMNM(J+1,I)) - IF(TMX.LT.0) THEN - OB8(1) = 1000 + ABS(NINT(TMX)) - ELSE - OB8(1) = NINT(TMX) - END IF - CF8(1) = 83 + INT(J/2) - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - END IF - ENDDO - ENDDO - END IF - END IF - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TP01');PC1=UFBINT_8 - IF(PC1.LT.10000) THEN - OB8(1) = E20O29(PC1) - CF8(1) = 85 - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TOSS');DUS=UFBINT_8 - IF(NINT(DUS).LT.1000) THEN - OB8(1) = NINT(98000. + DUS) - CF8(1) = 98 - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - IF(WSPD1.LT.BMISS) THEN - OB8(1) = NINT(WSPD1*10.) - CF8(1) = 924 - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - - CALL S03O29(OBS,SUBSET,*9999,*9998) - - RETURN - - 9999 CONTINUE - R04O29 = 999 - RETURN - - 9998 CONTINUE - print'(" IW3UNP29/R04O29: RPT with ID= ",A," TOSSED - ZERO ", - $ "CAT.1-6,51,52 LVLS")', SID - R04O29 = -9999 - KSKSFC =KSKSFC + 1 - RETURN - - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION R05O29(LUNIT,OBS) -C ---> formerly FUNCTION AIRCFT - - COMMON/IO29EE/POB(255),QOB(255),TOB(255),ZOB(255),DOB(255), - $ SOB(255),VSG(255),CLP(255),CLA(255),OB8(255), - $ CF8(255) - COMMON/IO29FF/PQM(255),QQM(255),TQM(255),ZQM(255),WQM(255), - $ QCP(255),QCA(255),Q81(255),Q82(255) - COMMON/IO29CC/SUBSET,IDAT10 - COMMON/IO29BB/KNDX,KSKACF(8),KSKUPA,KSKSFC,KSKSAT,KSKSMI - COMMON/IO29LL/BMISS - - CHARACTER*80 HDSTR,LVSTR,QMSTR,RCSTR,CRAWR - CHARACTER*8 SUBSET,SID,SIDO,SIDMOD,E35O29,RSV,RSV2,CCL,CRAW(1,255) - CHARACTER*1 PQM,QQM,TQM,ZQM,WQM,QCP,QCA,Q81,Q82,CTURB(0:14) - REAL(8) RID_8,RCL_8,UFBINT_8,RNS_8,BMISS - REAL(8) HDR_8(20),RCT_8(5,255),ARR_8(10,255),RAW_8(1,255) - DIMENSION OBS(*),HDR(20),RCT(5,255),ARR(10,255),RAW(1,255) - EQUIVALENCE (RID_8,SID),(RCL_8,CCL),(RAW_8,CRAW) - - SAVE - - DATA HDSTR/'RPID CLON CLAT HOUR MINU SECO '/ - DATA LVSTR/'PRLC TMDP TMDB WDIR WSPD '/ - DATA QMSTR/'QMPR QMAT QMDD QMGP QMWN '/ - DATA RCSTR/'RCHR RCMI RCTS '/ - - DATA CTURB/'0','1','2','3','0','1','2','3','0','1','2',4*'3'/ - -C CHECK IF THIS IS A PREPBUFR FILE -C -------------------------------- - - R05O29 = 99 -c#V#V#dak - future -cdak IF(SUBSET.EQ.'AIRCFT') R05O29 = PRPCFT(LUNIT,OBS) -cdak IF(SUBSET.EQ.'AIRCAR') R05O29 = PRPCFT(LUNIT,OBS) -caaaaadak - future - IF(R05O29.NE.99) RETURN - R05O29 = 0 - - CALL S05O29 - -C PUT THE HEADER INFORMATION INTO ON29 FORMAT -C ------------------------------------------- - - CALL UFBINT(LUNIT,HDR_8,20, 1,IRET,HDSTR);HDR(2:)=HDR_8(2:) - IF(IRET.EQ.0) SID = ' ' - CALL UFBINT(LUNIT,RCT_8, 5,255,NRCT,RCSTR);RCT=RCT_8 - IF(HDR(5).GE.BMISS) HDR(5) = 0 - IF(HDR(6).GE.BMISS) HDR(6) = 0 - RCTIM = NINT(RCT(1,1))+NINT(RCT(2,1))/60. - RID_8 = HDR_8(1) - XOB = HDR(2) - YOB = HDR(3) - RHR = BMISS - IF(HDR(4).LT.BMISS) RHR = NINT(HDR(4)) + ((NINT(HDR(5)) * 60.) + - $ NINT(HDR(6)))/3600. - RCH = RCTIM - -C TRY TO FIND FIND THE FLIGHT LEVEL HEIGHT -C ---------------------------------------- - - CALL UFBINT(LUNIT,HDR_8,20,1,IRET,'PSAL FLVL IALT HMSL PRLC') - HDR=HDR_8 - ELEV = BMISS - IF(HDR(5).LT.BMISS) ELEV = E03O29(HDR(5)*.01) - IF(HDR(4).LT.BMISS) ELEV = HDR(4) -C FOR MDCARS ACARS DATA ONLY: -C UNCOMMENTING NEXT LINE WILL SET P-ALT TO REPORTED "IALT" VALUE -- -C IN THIS CASE, PREPDATA WILL LATER GET PRESS. VIA STD. ATMOS. FCN. -C COMMENTING NEXT LINE WILL USE REPORTED PRESSURE "PRLC" TO GET -C P-ALT VIA INVERSE STD. ATMOS. FCN. -- IN THIS CASE, PREPDATA WILL -C LATER RETURN THIS SAME PRESS. VIA STD. ATMOS. FCN. -cdak IF(HDR(3).LT.BMISS) ELEV = HDR(3) - IF(HDR(2).LT.BMISS) ELEV = HDR(2) + SIGN(0.0000001,HDR(2)) - IF(HDR(1).LT.BMISS) ELEV = HDR(1) + SIGN(0.0000001,HDR(1)) - ELV = ELEV - -C ACFT NAVIGATION SYSTEM STORED IN INSTR. TYPE LOCATION (AS WITH ON29) -C -------------------------------------------------------------------- - - ITP = 99 - CALL UFBINT(LUNIT,RNS_8,1,1,IRET,'ACNS');RNS=RNS_8 - IF(RNS.LT.BMISS) THEN - IF(NINT(RNS).EQ.0) THEN - ITP = 97 - ELSE IF(NINT(RNS).EQ.1) THEN - ITP = 98 - END IF - END IF - - RTP = E33O29(SUBSET,SID) - - CALL UFBINT(LUNIT,RCL_8,1,1,IRET,'BORG') ! Effective 3/2002 - IF(IRET.EQ.0) THEN - CCL = ' ' - CALL UFBINT(LUNIT,RCL_8,1,1,IRET,'ICLI') ! Prior to 3/2002 - IF(IRET.EQ.0) CCL = ' ' - END IF -cvvvvv temporary? - IF(CCL(1:4).EQ.'KAWN') THEN - -C This will toss all Carswell/Tinker Aircraft reports - until Jack -C fixes the dup-check to properly remove the duplicate Carswell -C reports, we are better off removing them all since they are -C often of less quality than the non-Carswell AIREP reports -C RIGHT NOW WE ARE HAPPY WITH DUP-CHECKER'S HANDLING OF THESE, -C SO COMMENT THIS OUT - -cdak R05O29 = -9999 -cdak KSKACF(?) = KSKACF(?) + 1 -cdak RETURN - END IF -caaaaa temporary? - IF(SUBSET.EQ.'NC004003') THEN - -C ------------------------------------ -C ASDAR/AMDAR AIRCRAFT TYPE COME HERE -C ------------------------------------ - -cvvvvv temporary? -C Currently, we throw out any ASDAR/AMDAR reports with header "LFPW" - -C simply because they never appeared in NAS9000 ON29 AIRCFT data set -C (NOTE: These should all have ACID's that begin with "IT") -C (NOTE: These will not be removed from the new decoders, because -C they are apparently unique reports of reasonable -C quality. EMC just needs to test them in a parallel run -C to make sure prepacqc and the analysis handle them okay.) - -C NOTE: NO, NO DON'T THROW THEM OUT ANY MORE !!!!!! -C Keyser -- 6/13/97 - -CDAKCDAK if(ccl(1:4).eq.'LFPW') then -cppppp -cdak print'(" IW3UNP29/R05O29: TOSS ""LFPW"" AMDAR with ID = ",A, -cdak $ "; CCL = ",A)', SID,CCL(1:4) -cppppp -CDAKCDAK R05O29 = -9999 -CDAKCDAK kskacf(2) = kskacf(2) + 1 -CDAKCDAK return -CDAKCDAK end if -caaaaa temporary? - -C MODIFY REPORT ID AS WAS DONE IN OLD ON29 AIRCRAFT PACKER -C -------------------------------------------------------- - - CALL S06O29(SID,SIDMOD) - SIDO = SID - SID = SIDMOD - -C THE 25'TH (RESERVE) CHARACTER INDICATES PHASE OF FLIGHT -C THE 26'TH (RESERVE) CHARACTER INDICATES TEMPERATURE PRECISION -C THE 27'TH (RESERVE) CHARACTER INDICATES CARSWELL (NEVER HAPPENS) -C (NOTE: NAS9000 ONLY ASSIGNED HEADER "KAWN" AS CARSWELL, ALTHOUGH -C "PHWR" AND "EGWR" ARE ALSO APPARENTLY ALSO CARSWELL) - - RSV = '71 ' - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'POAF');POF=UFBINT_8 - IF(POF.LT.BMISS) WRITE(RSV(1:1),'(I1)') NINT(POF) - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'PCAT');PCT=UFBINT_8 - IF(NINT(PCT).GT.1) RSV(2:2) = '0' - IF(CCL(1:4).EQ.'KAWN') RSV(3:3) = 'C' - - ELSE IF(SUBSET.EQ.'NC004004') THEN - -C ------------------------------ -C ACARS AIRCRAFT TYPE COME HERE -C ------------------------------ - - CALL UFBINT(LUNIT,RID_8,1,1,IRET,'ACRN') - IF(IRET.EQ.0) SID = 'ACARS ' - KNDX = KNDX + 1 - RSV = '999 ' - - ELSE IF(SUBSET.EQ.'NC004001'.OR.SUBSET.EQ.'NC004002') THEN - -C ----------------------------------------- -C AIREP AND PIREP AIRCRAFT TYPES COME HERE -C ----------------------------------------- - -C MAY POSSIBLY NEED TO MODIFY THE RPID HERE -C ----------------------------------------- - - IF(SID(6:6).EQ.'Z') SID(6:6) = 'X' - IF(SID.EQ.'A '.OR.SID.EQ.' '.OR.SID(1:3).EQ.'ARP' - $ .OR.SID(1:3).EQ.'ARS') SID = 'AIRCFT ' - -cvvvvv temporary? -C Determined that Hickum AFB reports are much like Carswell - they have -C problems! They also are usually duplicates of either Carswell or -C non-Carswell reports. Apparently the front-end processing filters -C them out (according to B. Ballish). So, to make things match, -C we will do the same here. -C ACTUALLY, JEFF ATOR HAS REMOVED THESE FROM THE DECODER, SO WE -C SHOULD NEVER EVEN SEE THEM IN THE DATABASE, but it won't hurt -C anything to keep this in here. -C (NOTE: These all have headers of "PHWR") - - if(ccl(1:4).eq.'PHWR') then -cppppp -cdak print'(" IW3UNP29/R05O29: TOSS ""PHWR"" AIREP with ID = ",A, -cdak $ "; CCL = ",A)', SID,CCL(1:4) -cppppp - R05O29 = -9999 - kskacf(8) = kskacf(8) + 1 - return - end if -caaaaa temporary? - -cvvvvv temporary? -C 1) Carswell/Tinker AMDARS are processed as AIREP subtypes. -C Nearly all of them are duplicated as true non-Carswell AMDARS in -C the AMDAR subtype. The earlier version of the aircraft dup- -C checker could not remove such duplicates; the new verison now -C in operations can remove these. SO, WE HAVE COMMENTED THIS OUT. -C -C The Carswell AMDARS can be identified by the string " Sxyz" in -C the raw report (beyond byte 40), where y is 0,1, or 2. -C (NOTE: Apparently Carswell here applies to more headers than -C just "KAWN", so report header is not even checked.) - -C 2) Carswell/Tinker ACARS are processed as AIREP subtypes. -C These MAY duplicate true non-Carswell ACARS in the ACARS -C subtype. The NAS9000 decoder always excluded this type (no -C dup-checking was done). All of these will be removed here. -C The Carswell ACARS can be identified by the string " Sxyz" in -C the raw report (beyond byte 40), where y is 3 or greater. -C (NOTE: Apparently Carswell here applies to more headers than -C just "KAWN", so report header is not even checked.) - - call ufbint(lunit,raw_8,1,255,nlev,'RRSTG');raw=raw_8 - if(nlev.gt.5) then - ni = -7 - do mm = 6,nlev - ni = ni + 8 - crawr(ni:ni+7) = craw(1,mm) - if(ni+8.gt.80) go to 556 - enddo - 556 continue - do mm = 1,ni+7 - if(crawr(mm:mm+1).eq.' S') then - if((crawr(mm+2:mm+2).ge.'0'.and.crawr(mm+2:mm+2).le. - $ '9').or.crawr(mm+2:mm+2).eq.'/') then - if((crawr(mm+3:mm+3).ge.'0'.and.crawr(mm+3:mm+3) - $ .le.'9').or.crawr(mm+3:mm+3).eq.'/') then - if((crawr(mm+4:mm+4).ge.'0'.and. - $ crawr(mm+4:mm+4).le.'9').or.crawr(mm+4:mm+4) - $ .eq.'/') then -cppppp -cdak print'(" IW3UNP29/R05O29: For ",A,", raw_8(",I0,") = ",A)', -cdak $ SID,ni+7,crawr(1:ni+7) -cppppp - if(crawr(mm+3:mm+3).lt.'3') then - -C THIS IS A CARSWELL/TINKER AMDAR REPORT --> THROW OUT -C (NOT ANYMORE, DUP-CHECKER IS HANDLING THESE OKAY NOW) -C ---------------------------------------------------- - -cppppp -cdak print'(" IW3UNP29/R05O29: Found a Carswell AMDAR for ",A, -cdak $ "; CCL = ",A)', SID,CCL(1:4) -cppppp -cdak R05O29 = -9999 -cdak KSKACF(3) = KSKACF(3) + 1 -cdak RETURN - else - -C THIS IS A CARSWELL/TINKER ACARS REPORT --> THROW OUT -C ---------------------------------------------------- - -cppppp -cdak print'(" IW3UNP29/R05O29: Found a Carswell ACARS for ",A, -cdak $ "; CCL = ",A)', SID,CCL(1:4) -cppppp - R05O29 = -9999 - KSKACF(4) = KSKACF(4) + 1 - RETURN - - end if - end if - end if - end iF - end if - if(mm+5.gt.ni+7) go to 557 - enddo - 557 continue - END IF -caaaaa temporary? - -C THE 25'TH (RESERVE) CHARACTER INDICATES 8'TH CHARACTER OF STATION ID -C THE 26'TH (RESERVE) CHARACTER INDICATES 7'TH CHARACTER OF STATION ID -C THE 27'TH (RESERVE) CHARACTER INDICATES CARSWELL -C (NOTE: NAS9000 ONLY ASSIGNED HEADER "KAWN" AS CARSWELL, ALTHOUGH -C "PHWR" AND "EGWR" ARE ALSO APPARENTLY ALSO CARSWELL) - - RSV = SID(8:8)//SID(7:7)//' ' - IF(CCL(1:4).EQ.'KAWN') RSV(3:3) = 'C' - - END IF - -C ----------------------------- -C ALL AIRCRAFT TYPES COME HERE -C ----------------------------- - - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'DGOT');DGT=UFBINT_8 - -C PUT THE LEVEL DATA INTO ON29 UNITS -C ---------------------------------- - - CALL UFBINT(LUNIT,ARR_8,10,255,NLEV,LVSTR);ARR=ARR_8 - DO L=1,NLEV - -Cvvvvv temporary? -C Even though PREPDATA filters out any aircraft reports with a missing -C wind, or AIREP/PIREP and AMDAR reports below 100 and 2286 meters, -C respectively, it will be done here for now in order to help in -C the comparison between counts coming from the Cray dumps and the -C NAS9000 ON29 dumps (the NAS9000 ON29 maker filters these out). - -C NO, NO LET'S NOT FILTER HERE ANY MORE - LEAVE IT UP TO PREPDATA -C SINCE WE AREN'T COMPARING NAS9000 AND CRAY COUNTS ANY MORE -C Keyser -- 6/13/97 - -CDAKCDAK if(arr(4,1).ge.bmiss.or.arr(5,1).ge.bmiss) then -CDAKCDAK R05O29 = -9999 -CDAKCDAK kskacf(5) = kskacf(5) + 1 -CDAKCDAK return -CDAKCDAK end if -CDAKCDAK if(subset.eq.'NC004003'.and.elev.lt.2286.) then -CDAKCDAK R05O29 = -9999 -CDAKCDAK kskacf(6) = kskacf(6) + 1 -CDAKCDAK return -CDAKCDAK else if(subset.ne.'NC004004'.and.elev.lt.100.) then -CDAKCDAK R05O29 = -9999 -CDAKCDAK kskacf(7) = kskacf(7) + 1 -CDAKCDAK return -CDAKCDAK end if -caaaaa temporary? - - POB(L) = E01O29(ARR(1,L)) - QOB(L) = E07O29(ARR(2,L),ARR(3,L)) - TOB(L) = E06O29(ARR(3,L)) - ZOB(L) = ELEV - DOB(L) = E04O29(ARR(4,L),ARR(5,L)) - SOB(L) = E05O29(ARR(4,L),ARR(5,L)) - ENDDO - WSPD1 = ARR(5,1) - - CALL UFBINT(LUNIT,ARR_8,10,255,NLEV,QMSTR);ARR=ARR_8 - - IF(SUBSET.EQ.'NC004004') THEN - -C --------------------------------------------------------- -C ACARS AIRCRAFT TYPE COME HERE FOR QUALITY MARK ASSIGNMENT -C --------------------------------------------------------- - - DO L=1,NLEV - PQM(L) = E35O29(ARR(1,L)) - TQM(L) = E35O29(ARR(2,L)) - QQM(L) = E35O29(ARR(3,L)) - ZQM(L) = E35O29(ARR(4,L)) - WQM(L) = E35O29(ARR(5,L)) - ENDDO - -C DEFAULT Q.MARK FOR WIND: "A" -C ---------------------------- - - IF(NLEV.EQ.0.OR.ARR(5,1).GE.BMISS) WQM(1) = 'A' - - ELSE - -C -------------------------------------------------------------- -C ALL OTHER AIRCRAFT TYPES COME HERE FOR QUALITY MARK ASSIGNMENT -C -------------------------------------------------------------- - - DO L=1,NLEV - ARR(4,L) = 2 - -C IF KEEP FLAG ON WIND, ENTIRE REPORT GETS KEEP FLAG ('H' IN ZQM) -C -- unless.... -C IF PURGE FLAG ON WIND, ENTIRE REPORT GETS PURGE FLAG ('P' IN ZQM) -C IF PURGE FLAG ON TEMP, ENTIRE REPORT GETS PURGE FLAG ('P' IN ZQM) -C IF FAIL FLAG ON WIND, ENTIRE REPORT GETS FAIL FLAG ('F' IN ZQM) -C IF FAIL FLAG ON TEMP, ENTIRE REPORT GETS FAIL FLAG ('F' IN ZQM) -C ----------------------------------------------------------------- - - IF(ARR(5,L).EQ.0.AND.(ARR(2,L).LT.10.OR.ARR(2,L).GT.15))THEN - ARR(4,L) = 0 - ELSE IF(ARR(5,L).EQ.14.OR.ARR(2,L).EQ.14) THEN - ARR(4,L) = 14 - ELSE IF(ARR(5,L).EQ.13.OR.ARR(2,L).EQ.13) THEN - ARR(4,L) = 13 - END IF - PQM(L) = ' ' - TQM(L) = ' ' - QQM(L) = ' ' - ZQM(L) = E35O29(ARR(4,L)) - -C DEGREE OF TURBULENCE IS STORED IN MOISTURE Q.M. SLOT -C ---------------------------------------------------- - - IF(NINT(DGT).LT.15) QQM(L) = CTURB(NINT(DGT)) - ENDDO - -C DEFAULT Q.MARK FOR WIND: "C" -C ---------------------------- - - WQM(1) = 'C' - END IF - -C PUT THE UNPACKED ON29 REPORT INTO OBS -C ------------------------------------- - - RSV2 = ' ' - CALL S01O29(SID,XOB,YOB,RHR,RCH,RSV,RSV2,ELV,ITP,RTP) - CALL S02O29(6,1,*9999) - -C ------------------------------------------------------------------ -C MISC DATA GOES INTO CATEGORY 08 -C ------------------------------------------------------------------ -C CODE FIGURE 021 - REPORT SEQUENCE NUMBER -C CODE FIGURE 917 - CHARACTERS 1 AND 2 OF ACTUAL STATION IDENTIFICATION -C (CURRENTLY ONLY FOR ASDAR/AMDAR) -C CODE FIGURE 918 - CHARACTERS 3 AND 4 OF ACTUAL STATION IDENTIFICATION -C (CURRENTLY ONLY FOR ASDAR/AMDAR) -C CODE FIGURE 919 - CHARACTERS 5 AND 6 OF ACTUAL STATION IDENTIFICATION -C (CURRENTLY ONLY FOR ASDAR/AMDAR) -C CODE FIGURE 920 - CHARACTERS 7 AND 8 OF ACTUAL STATION IDENTIFICATION -C (CURRENTLY ONLY FOR ASDAR/AMDAR AND ACARS) -C CODE FIGURE 921 - OBSERVATION TIME TO NEAREST 1000'TH OF AN HOUR -C (CURRENTLY ONLY FOR ACARS) -C CODE FIGURE 922 - FIRST TWO CHARACTERS OF BULLETIN BEING MONITORED -C CODE FIGURE 923 - LAST TWO CHARACTERS OF BULLETIN BEING MONITORED -C CODE FIGURE 924 - WIND SPEED IN 0.01*M/S -C ------------------------------------------------------------------ - - IF(SUBSET.EQ.'NC004004') THEN - OB8(1) = KNDX - CF8(1) = 21 - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - OB8(1) = 99999. - Q81(1) = SID(7:7) - Q82(1) = SID(8:8) - CF8(1) = 920 - CALL S02O29(8,1,*9999) - IF(RHR.LT.BMISS) THEN - OB8(1) = NINT((RHR*1000.)+0.0000001) - CF8(1) = 921 - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - ELSE IF(SUBSET.EQ.'NC004003') THEN - DO KKK = 1,4 - OB8(KKK) = 99999. - Q81(KKK) = SIDO(2*KKK-1:2*KKK-1) - Q82(KKK) = SIDO(2*KKK:2*KKK) - CF8(KKK) = 916 + KKK - CALL S02O29(8,KKK,*9999) - ENDDO - END IF - IF(CCL.NE.' ') THEN - OB8(2) = 99999. - Q81(2) = CCL(1:1) - Q82(2) = CCL(2:2) - CF8(2) = 922 - CALL S02O29(8,2,*9999) - OB8(3) = 99999. - Q81(3) = CCL(3:3) - Q82(3) = CCL(4:4) - CF8(3) = 923 - CALL S02O29(8,3,*9999) - END IF - IF(WSPD1.LT.BMISS) THEN - OB8(4) = NINT(WSPD1*10.) - CF8(4) = 924 - Q81(4) = ' ' - Q82(4) = ' ' - CALL S02O29(8,4,*9999) - END IF - - CALL S03O29(OBS,SUBSET,*9999,*9998) - - RETURN - - 9999 CONTINUE - R05O29 = 999 - RETURN - - 9998 CONTINUE - print'(" IW3UNP29/R05O29: RPT with ID= ",A," TOSSED - ZERO ", - $ "CAT.1-6,51,52 LVLS")', SID - R05O29 = -9999 - KSKACF(1) = KSKACF(1) + 1 - RETURN - - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION R06O29(LUNIT,OBS) -C ---> formerly FUNCTION SATWND - - COMMON/IO29EE/POB(255),QOB(255),TOB(255),ZOB(255),DOB(255), - $ SOB(255),VSG(255),CLP(255),CLA(255),OB8(255), - $ CF8(255) - COMMON/IO29FF/PQM(255),QQM(255),TQM(255),ZQM(255),WQM(255), - $ QCP(255),QCA(255),Q81(255),Q82(255) - COMMON/IO29CC/SUBSET,IDAT10 - COMMON/IO29BB/KNDX,KSKACF(8),KSKUPA,KSKSFC,KSKSAT,KSKSMI - COMMON/IO29KK/KOUNT(499,18) - COMMON/IO29LL/BMISS - - CHARACTER*80 HDSTR,LVSTR,QMSTR,RCSTR - CHARACTER*8 SUBSET,SID,E35O29,RSV,RSV2 - CHARACTER*3 CINDX3 - CHARACTER*1 PQM,QQM,TQM,ZQM,WQM,QCP,QCA,Q81,Q82,CSAT(499), - $ CPRD(9),CINDX7,C7(26),CPROD(0:4),CPRDF(3) - INTEGER IPRDF(3) - REAL(8) RID_8,UFBINT_8,BMISS - REAL(8) HDR_8(20),RCT_8(5,255),ARR_8(10,255) - DIMENSION OBS(*),HDR(20),RCT(5,255),ARR(10,255) - EQUIVALENCE (RID_8,SID) - - SAVE - - DATA HDSTR/'RPID CLON CLAT HOUR MINU SAID '/ - DATA LVSTR/'PRLC TMDP TMDB WDIR WSPD '/ - DATA QMSTR/'QMPR QMAT QMDD QMGP SWQM '/ - DATA RCSTR/'RCHR RCMI RCTS '/ - - DATA CSAT /'A','B','C','D',45*'?','Z','W','X','Y','Z','W','X', - $ 'Y','Z','W',90*'?','R','O','P','Q','R','O','P','Q','R','O', - $ 339*'?','V'/ - DATA CPROD /'C','D','?','?','E'/ - DATA CPRDF /'C','B','V'/ - DATA IPRDF / 1 , 6 , 4 / - DATA CPRD /'C','V','I','W','P','T','L','Z','G'/ - DATA C7 /'A','B','C','D','E','F','G','H','I','J','K','L','M', - $ 'N','O','P','Q','R','S','T','U','V','W','X','Y','Z'/ - -C CHECK IF THIS IS A PREPBUFR FILE -C -------------------------------- - - R06O29 = 99 -c#V#V#dak - future -cdak IF(SUBSET.EQ.'SATWND') R06O29 = PRPWND(LUNIT,OBS) -caaaaadak - future - IF(R06O29.NE.99) RETURN - R06O29 = 0 - - CALL S05O29 - -C TRY TO FIND FIND THE HEIGHT ASSIGNMENT -C -------------------------------------- - - CALL UFBINT(LUNIT,HDR_8,20,1,IRET,'HGHT PRLC');HDR=HDR_8 - ELEV = BMISS - IF(HDR(2).LT.BMISS) ELEV = E03O29(HDR(2)*.01) - IF(HDR(1).LT.BMISS) ELEV = HDR(1) - -C PUT THE HEADER INFORMATION INTO ON29 FORMAT -C ------------------------------------------- - - CALL UFBINT(LUNIT,HDR_8,20, 1,IRET,HDSTR);HDR(2:)=HDR_8(2:) - CALL UFBINT(LUNIT,RCT_8, 5,255,NRCT,RCSTR);RCT=RCT_8 - IF(HDR(5).GE.BMISS) HDR(5) = 0 - RCTIM = NINT(RCT(1,1))+NINT(RCT(2,1))/60. - RID_8 = HDR_8(1) - XOB = HDR(2) - YOB = HDR(3) - RHR = BMISS - IF(HDR(4).LT.BMISS) RHR = NINT(HDR(4))+NINT(HDR(5))/60. - RCH = RCTIM - RSV = '990 ' - -C THE 25'TH (RESERVE) CHARACTER IS THE CLOUD MASK/DEEP LAYER INDICATOR -C {=2 - CLOUD TOP (NORMAL CLOUD DRIFT), =1 - DEEP LAYER, -C =9 - INDICATOR MISSING, THUS REVERTS TO DEFAULT CLOUD TOP} -C (=9 FOR ALL BUT U.S. HIGH-DENSITY SATWND TYPES) -C -------------------------------------------------------------------- - -C THE 27'TH (RESERVE) CHARACTER INDICATES THE PRODUCER OF THE SATWND -C ------------------------------------------------------------------ - -C THE INSTRUMENT TYPE INDICATES THE PRODUCT TYPE -C ---------------------------------------------- - - ITP = 99 - -C REPROCESS THE STN. ID -C --------------------- - -C REPROCESSED CHAR 1 -----> GOES: BUFR CHAR 1 -C -----> METEOSAT: SAT. NO. 52, 56 GET 'X' -C SAT. NO. 53, 57 GET 'Y' -C SAT. NO. 50, 54, 58 GET 'Z' -C SAT. NO. 51, 55, 59 GET 'W' -C -----> GMS(JA): SAT. NO. 152,156 GET 'P' -C SAT. NO. 153,157 GET 'Q' -C SAT. NO. 150,154,158 GET 'R' -C SAT. NO. 151,155,159 GET 'O' -C -----> INSAT: SAT. NO. 499 GET 'V' -C REPROCESSED CHAR 2 -----> GOES: RETURNED VALUE IN BUFR FOR 'SWPR' -C (PRODUCER) -C -----> OTHERS: SAT. PRODUCER -- ESA GET 'C' -C -- GMS GET 'D' -C -- INSAT GET 'E' -C REPROCESSED CHAR 6 -----> GOES: BUFR CHAR 6 -C -----> OTHERS -- INFRA-RED CLOUD DRIFT GET 'C' -C -- VISIBLE CLOUD DRIFT GET 'B' -C -- WATER VAPOR GET 'V' -C REPROCESSED CHAR 3-5 ---> SEQUENTIAL SERIAL INDEX (001 - 999) -C (UNIQUE FOR EACH BUFR CHAR 1/6 COMB.) -C REPROCESSED CHAR 7 -----> GROUP NUMBER FOR SERIAL INDEX IN -C REPROCESSED CHAR 3-5 (0 - 9, A - Z) -C REPROCESSED CHAR 8 -----> ALWAYS BLANK (' ') FOR NOW - - READ(SUBSET(8:8),'(I1)') INUM - IF(SID(1:1).GE.'A'.AND.SID(1:1).LE.'D') THEN - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'SWPR');SWPR=UFBINT_8 - IF(NINT(SWPR).GT.0.AND.NINT(SWPR).LT.10) - $ WRITE(RSV(3:3),'(I1)') NINT(SWPR) - SID(2:2) = RSV(3:3) - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'SWTP');SWTP=UFBINT_8 - IF(SWTP.LT.BMISS) ITP = NINT(SWTP) - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'SWDL');SWDL=UFBINT_8 - IF(NINT(SWDL).GT.-1.AND.NINT(SWDL).LT.10) - $ WRITE(RSV(1:1),'(I1)') NINT(SWDL) - ELSE - SID = '????????' - IF(NINT(HDR(6)).LT.500) THEN - SID(1:1) = CSAT(NINT(HDR(6))) - SID(2:2) = CPROD(NINT(HDR(6))/100) - RSV(3:3) = SID(2:2) - END IF - IF(INUM.LT.4) THEN - SID(6:6) = CPRDF(INUM) - ITP = IPRDF(INUM) - END IF - END IF - CINDX3 = '???' - CINDX7 = '?' - IF(NINT(HDR(6)).LT.500.AND.ITP.LT.19) THEN - KOUNT(NINT(HDR(6)),ITP) = MIN(KOUNT(NINT(HDR(6)),ITP)+1,35999) - KOUNT3 = MOD(KOUNT(NINT(HDR(6)),ITP),1000) - KOUNT7 = INT(KOUNT(NINT(HDR(6)),ITP)/1000) - WRITE(CINDX3,'(I3.3)') KOUNT3 - IF(KOUNT7.LT.10) THEN - WRITE(CINDX7,'(I1.1)') KOUNT7 - ELSE - CINDX7 = C7(KOUNT7-9) - END IF - END IF - SID = SID(1:2)//CINDX3//SID(6:6)//CINDX7//' ' - - ELV = ELEV - RTP = E33O29(SUBSET,SID) - -C PUT THE LEVEL DATA INTO ON29 UNITS -C ---------------------------------- - - CALL UFBINT(LUNIT,ARR_8,10,255,NLEV,LVSTR);ARR=ARR_8 - DO L=1,NLEV - POB(L) = E01O29(ARR(1,L)) - -C GROSS CHECK ON PRESSURE -C ----------------------- - - IF(NINT(POB(L)).EQ.0) THEN - print'(" ~~IW3UNP29/R06O29: RPT with ID= ",A," TOSSED - ", - $ "PRES. IS ZERO MB")', SID - R06O29 = -9999 - KSKSAT = KSKSAT + 1 - RETURN - END IF - - QOB(L) = E07O29(ARR(2,L),ARR(3,L)) - TOB(L) = E06O29(ARR(3,L)) - ZOB(L) = ELEV - DOB(L) = E04O29(ARR(4,L),ARR(5,L)) - SOB(L) = E05O29(ARR(4,L),ARR(5,L)) - ENDDO - WSPD1 = ARR(5,1) - -C DETERMINE QUALITY MARKERS -C ------------------------- - - CALL UFBINT(LUNIT,ARR_8,10,255,NLEV,QMSTR);ARR=ARR_8 - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'RFFL');RFFL=UFBINT_8 - IF(RFFL.LT.BMISS.AND.(NINT(ARR(5,1)).EQ.2.OR.NINT(ARR(5,1)).GE. - $ BMISS)) THEN - IF(NINT(RFFL).GT.84) THEN - ARR(5,1) = 1 - ELSE IF(NINT(RFFL).GT.55) THEN - ARR(5,1) = 2 - ELSE IF(NINT(RFFL).GT.49) THEN - ARR(5,1) = 3 - ELSE - ARR(5,1) = 13 - END IF - END IF - - DO L=1,NLEV - WQM(L) = E35O29(ARR(5,L)) - - IF(WQM(L).EQ.'R'.OR.WQM(L).EQ.'P'.OR.WQM(L).EQ.'F') THEN - -C A REJECT, PURGE, OR FAIL FLAG ON WIND IS TRANSFERRED TO ALL VARIABLES -C --------------------------------------------------------------------- - - PQM(L) = WQM(L) - TQM(L) = WQM(L) - QQM(L) = WQM(L) - ZQM(L) = WQM(L) - - ELSE - - PQM(L) = E35O29(ARR(1,L)) - TQM(L) = E35O29(ARR(2,L)) - QQM(L) = E35O29(ARR(3,L)) - ZQM(L) = E35O29(ARR(4,L)) - - END IF - - ENDDO - -C PUT THE UNPACKED ON29 REPORT INTO OBS -C ------------------------------------- - - RSV2 = ' ' - CALL S01O29(SID,XOB,YOB,RHR,RCH,RSV,RSV2,ELV,ITP,RTP) - CALL S02O29(6,1,*9999) - -C --------------------------------------------------------------------- -C MISC DATA GOES INTO CATEGORY 08 -C --------------------------------------------------------------------- -C CODE FIGURE 013 - PRESSURE -C CODE FIGURE 920 - CHARACTERS 7 AND 8 OF ACTUAL STATION IDENTIFICATION -C (CURRENTLY ONLY APPLIES TO U.S. SATWND TYPES) -C CODE FIGURE 924 - WIND SPEED IN 0.01*M/S -C --------------------------------------------------------------------- -C --------------------------------------------------------------------- - - IF(POB(1).LT.BMISS) THEN - OB8(1) = NINT(POB(1)*0.1) - CF8(1) = 13 - Q81(1) = ' ' - Q82(1) = ' ' - CALL S02O29(8,1,*9999) - END IF - IF(SID(1:1).GE.'A'.AND.SID(1:1).LE.'D') THEN - OB8(1) = 99999. - Q81(1) = SID(7:7) - Q82(1) = SID(8:8) - CF8(1) = 920 - CALL S02O29(8,1,*9999) - END IF - IF(WSPD1.LT.BMISS) THEN - OB8(2) = NINT(WSPD1*10.) - CF8(2) = 924 - Q81(2) = ' ' - Q82(2) = ' ' - CALL S02O29(8,2,*9999) - END IF - - CALL S03O29(OBS,SUBSET,*9999,*9998) - - RETURN - - 9999 CONTINUE - R06O29 = 999 - RETURN - - 9998 CONTINUE - print'(" IW3UNP29/R06O29: RPT with ID= ",A," TOSSED - ZERO ", - $ "CAT.1-6,51,52 LVLS")', SID - R06O29 = -9999 - KSKSAT =KSKSAT + 1 - RETURN - - END -C*********************************************************************** -C*********************************************************************** -C*********************************************************************** - FUNCTION R07O29(LUNIT,OBS) -C ---> formerly FUNCTION SPSSMI - - COMMON/IO29EE/POB(255),QOB(255),TOB(255),ZOB(255),DOB(255), - $ SOB(255),VSG(255),CLP(255),CLA(255),OB8(255), - $ CF8(255) - COMMON/IO29FF/PQM(255),QQM(255),TQM(255),ZQM(255),WQM(255), - $ QCP(255),QCA(255),Q81(255),Q82(255) - COMMON/IO29CC/SUBSET,IDAT10 - COMMON/IO29BB/KNDX,KSKACF(8),KSKUPA,KSKSFC,KSKSAT,KSKSMI - COMMON/IO29LL/BMISS - - CHARACTER*80 HDSTR - CHARACTER*8 SUBSET,SID,RSV,RSV2 - CHARACTER*4 CSTDV - CHARACTER*1 PQM,QQM,TQM,ZQM,WQM,QCP,QCA,Q81,Q82,CRF - REAL(8) RID_8,UFBINT_8,HDR_8(20),TMBR_8(7),ADDP_8(5),PROD_8(2,2) - REAL(8) BMISS - DIMENSION OBS(*),HDR(20),ADDP(5),PROD(2,2),TMBR(7) - - EQUIVALENCE (RID_8,SID) - - SAVE - - DATA HDSTR/'RPID CLON CLAT HOUR MINU SECO NMCT SAID '/ - -C CHECK IF THIS IS A PREPBUFR FILE -C -------------------------------- - - R07O29 = 99 -c#V#V#dak - future -cdak IF(SUBSET.EQ.'SPSSMI') R07O29 = PRPSMI(LUNIT,OBS) -caaaaadak - future - IF(R07O29.NE.99) RETURN - R07O29 = 0 - - CALL S05O29 - -C PUT THE HEADER INFORMATION INTO ON29 FORMAT -C ------------------------------------------- - - CALL UFBINT(LUNIT,HDR_8,20, 1,IRET,HDSTR);HDR(2:)=HDR_8(2:) - IF(HDR(5).GE.BMISS) HDR(5) = 0 - IF(HDR(6).GE.BMISS) HDR(6) = 0 - RID_8 = HDR_8(1) - XOB = HDR(2) - YOB = HDR(3) - RHR = BMISS - IF(HDR(4).LT.BMISS) RHR = NINT(HDR(4)) + ((NINT(HDR(5)) * 60.) + - $ NINT(HDR(6)))/3600. - RCH = 99999. - ELV = 99999. - ITP = 99 - RTP = HDR(7) - -C CHECK ON VALUE FOR SATELLITE ID TO DETERMINE IF THIS IS A SUPEROB -C (SATELLITE ID IS MISSING FOR SUPEROBS) -C ----------------------------------------------------------------- - - ISUPOB = 1 - IF(HDR(8).LT.BMISS) ISUPOB = 0 - -C+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ - - STDV = BMISS - -C PUT THE SSM/I DATA INTO ON29 UNITS (WILL RETURN TO HEADER DATA LATER) -C ALL PROCESSING GOES INTO CATEGORY 08 -C --------------------------------------------------------------------- - - IF(RTP.EQ.68) THEN -C --------------------------------------------------------------------- -C ** 7-CHANNEL BRIGHTNESS TEMPERATURES -- REPORT TYPE 68 ** -C --------------------------------------------------------------------- -C CODE FIGURE 189 - 19 GHZ V BRIGHTNESS TEMPERATURE (DEG. K X 100) -C CODE FIGURE 190 - 19 GHZ H BRIGHTNESS TEMPERATURE (DEG. K X 100) -C CODE FIGURE 191 - 22 GHZ V BRIGHTNESS TEMPERATURE (DEG. K X 100) -C CODE FIGURE 192 - 37 GHZ V BRIGHTNESS TEMPERATURE (DEG. K X 100) -C CODE FIGURE 193 - 37 GHZ H BRIGHTNESS TEMPERATURE (DEG. K X 100) -C CODE FIGURE 194 - 85 GHZ V BRIGHTNESS TEMPERATURE (DEG. K X 100) -C CODE FIGURE 195 - 85 GHZ H BRIGHTNESS TEMPERATURE (DEG. K X 100) -C --------------------------------------------------------------------- - NLCAT8 = 7 - CALL UFBINT(LUNIT,TMBR_8,1,7,NLEV,'TMBR');TMBR=TMBR_8 - DO NCHN = 1,7 - OB8(NCHN) = MIN(NINT(TMBR(NCHN)*100.),99999) - CF8(NCHN) = 188 + NCHN - ENDDO - ELSE IF(RTP.EQ.575) THEN -C --------------------------------------------------------------------- -C ** ADDITIONAL PRODUCTS -- REPORT TYPE 575 ** -C --------------------------------------------------------------------- -C CODE FIGURE 210 - SURFACE TAG (RANGE: 0,1,3-6) -C CODE FIGURE 211 - ICE CONCENTRATION (PERCENT) -C CODE FIGURE 212 - ICE AGE (RANGE: 0,1) -C CODE FIGURE 213 - ICE EDGE (RANGE: 0,1) -C CODE FIGURE 214 - CALCULATED SURFACE TYPE (RANGE: 1-20) -C --------------------------------------------------------------------- - NLCAT8 = 5 - CALL UFBINT(LUNIT,ADDP_8,5,1,IRET,'SFTG ICON ICAG ICED SFTP') - ADDP=ADDP_8 - DO NADD = 1,5 - IF(ADDP(NADD).LT.BMISS) THEN - OB8(NADD) = NINT(ADDP(NADD)) - CF8(NADD) = 209 + NADD - END IF - ENDDO - ELSE IF(RTP.EQ.571) THEN -C --------------------------------------------------------------------- -C ** OCEAN SURFACE WIND SPEED PRODUCT -- REPORT TYPE 571 ** -C --------------------------------------------------------------------- -C CODE FIGURE 196 - OCEANIC WIND SPEED (M/S * 10) -C (RAIN FLAG IN Q.M. BYTE 2) -C --------------------------------------------------------------------- - CF8(1) = 196 - ELV = 0 - NLCAT8 = 1 - IF(ISUPOB.EQ.1) THEN - CALL UFBREP(LUNIT,PROD_8,2,2,IRET,'FOST WSOS');PROD=PROD_8 - DO JJ = 1,2 - IF(PROD(1,JJ).EQ.4) THEN - OB8(1) = NINT(PROD(2,JJ)*10.) - ELSE IF(PROD(1,JJ).EQ.10) THEN - STDV = NINT(PROD(2,JJ)*100.) - END IF - ENDDO - ELSE - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'WSOS');PRODN=UFBINT_8 - OB8(1) = NINT(PRODN*10.) - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'RFLG');RFLG=UFBINT_8 - IF(RFLG.LT.BMISS) THEN - WRITE(CRF,'(I1.1)') NINT(RFLG) - Q82(1) = CRF - END IF - END IF - ELSE IF(RTP.EQ.65) THEN -C --------------------------------------------------------------------- -C ** OCEAN TOTAL PRECIPITABLE WATER PRODUCT -- REPORT TYPE 65 ** -C --------------------------------------------------------------------- -C CODE FIGURE 197 - TOTAL PRECIPITABLE WATER (MM * 10) -C (RAIN FLAG IN Q.M. BYTE 2) -C --------------------------------------------------------------------- - CF8(1) = 197 - ELV = 0 - NLCAT8 = 1 - IF(ISUPOB.EQ.1) THEN - CALL UFBREP(LUNIT,PROD_8,2,2,IRET,'FOST PH2O');PROD=PROD_8 - DO JJ = 1,2 - IF(PROD(1,JJ).EQ.4) THEN - OB8(1) = NINT(PROD(2,JJ)*10.) - ELSE IF(PROD(1,JJ).EQ.10) THEN - STDV = NINT(PROD(2,JJ)*100.) - END IF - ENDDO - ELSE - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'PH2O');PRODN=UFBINT_8 - OB8(1) = NINT(PRODN*10.) - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'RFLG');RFLG=UFBINT_8 - IF(RFLG.LT.BMISS) THEN - WRITE(CRF,'(I1)') NINT(RFLG) - Q82(1) = CRF - END IF - END IF - ELSE IF(RTP.EQ.66) THEN -C --------------------------------------------------------------------- -C ** LAND/OCEAN RAINFALL RATE -- REPORT TYPE 66 ** -C --------------------------------------------------------------------- -C CODE FIGURE 198 - RAINFALL RATE (MM/HR) -C --------------------------------------------------------------------- - CF8(1) = 198 - NLCAT8 = 1 - IF(ISUPOB.EQ.1) THEN - CALL UFBREP(LUNIT,PROD_8,2,2,IRET,'FOST REQV');PROD=PROD_8 - DO JJ = 1,2 - IF(PROD(1,JJ).EQ.4) THEN - OB8(1) = NINT(PROD(2,JJ)*3600.) - ELSE IF(PROD(1,JJ).EQ.10) THEN - STDV = NINT(PROD(2,JJ)*36000.) - END IF - ENDDO - ELSE - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'REQV');PRODN=UFBINT_8 - OB8(1) = NINT(PRODN*3600.) - END IF - ELSE IF(RTP.EQ.576) THEN -C --------------------------------------------------------------------- -C ** SURFACE TEMPERATURE -- REPORT TYPE 576 ** -C --------------------------------------------------------------------- -C CODE FIGURE 199 - SURFACE TEMPERATURE (DEGREES KELVIN) -C --------------------------------------------------------------------- - CF8(1) = 199 - NLCAT8 = 1 - IF(ISUPOB.EQ.1) THEN - CALL UFBREP(LUNIT,PROD_8,2,2,IRET,'FOST TMSK');PROD=PROD_8 - DO JJ = 1,2 - IF(PROD(1,JJ).EQ.4) THEN - OB8(1) = NINT(PROD(2,JJ)) - ELSE IF(PROD(1,JJ).EQ.10) THEN - STDV = NINT(PROD(2,JJ)*10.) - END IF - ENDDO - ELSE - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'TMSK');PRODN=UFBINT_8 - OB8(1) = NINT(PRODN) - END IF - ELSE IF(RTP.EQ.69) THEN -C --------------------------------------------------------------------- -C ** OCEAN CLOUD WATER -- REPORT TYPE 69 ** -C --------------------------------------------------------------------- -C CODE FIGURE 200 - CLOUD WATER (MM * 100) -C --------------------------------------------------------------------- - CF8(1) = 200 - ELV = 0 - NLCAT8 = 1 - IF(ISUPOB.EQ.1) THEN - CALL UFBREP(LUNIT,PROD_8,2,2,IRET,'FOST CH2O');PROD=PROD_8 - DO JJ = 1,2 - IF(PROD(1,JJ).EQ.4) THEN - OB8(1) = NINT(PROD(2,JJ)*100.) - ELSE IF(PROD(1,JJ).EQ.10) THEN - STDV = NINT(PROD(2,JJ)*1000.) - END IF - ENDDO - ELSE - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'CH2O');PRODN=UFBINT_8 - OB8(1) = NINT(PRODN*100.) - END IF - ELSE IF(RTP.EQ.573) THEN -C --------------------------------------------------------------------- -C ** SOIL MOISTURE -- REPORT TYPE 573 ** -C --------------------------------------------------------------------- -C CODE FIGURE 201 - SOIL MOISTURE (MM) -C --------------------------------------------------------------------- - CF8(1) = 201 - NLCAT8 = 1 - IF(ISUPOB.EQ.1) THEN - CALL UFBREP(LUNIT,PROD_8,2,2,IRET,'FOST SMOI');PROD=PROD_8 - DO JJ = 1,2 - IF(PROD(1,JJ).EQ.4) THEN - OB8(1) = NINT(PROD(2,JJ)*1000.) - ELSE IF(PROD(1,JJ).EQ.10) THEN - STDV = NINT(PROD(2,JJ)*10000.) - END IF - ENDDO - ELSE - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'SMOI');PRODN=UFBINT_8 - OB8(1) = NINT(PRODN*1000.) - END IF - ELSE IF(RTP.EQ.574) THEN -C --------------------------------------------------------------------- -C ** SNOW DEPTH -- REPORT TYPE 574 ** -C --------------------------------------------------------------------- -C CODE FIGURE 202 - SNOW DEPTH (MM) -C --------------------------------------------------------------------- - CF8(1) = 202 - NLCAT8 = 1 - IF(ISUPOB.EQ.1) THEN - CALL UFBREP(LUNIT,PROD_8,2,2,IRET,'FOST SNDP');PROD=PROD_8 - DO JJ = 1,2 - IF(PROD(1,JJ).EQ.4) THEN - OB8(1) = NINT(PROD(2,JJ)*1000.) - ELSE IF(PROD(1,JJ).EQ.10) THEN - STDV = NINT(PROD(2,JJ)*10000.) - END IF - ENDDO - ELSE - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'SNDP');PRODN=UFBINT_8 - OB8(1) = NINT(PRODN*1000.) - END IF - END IF - -C+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ - -C FINISH PUTTING THE HEADER INFORMATION INTO ON29 FORMAT -C ------------------------------------------------------ - - RSV = '999 ' - RSV2 = ' ' - - IF(STDV.LT.BMISS) THEN - WRITE(CSTDV,'(I4.4)') NINT(STDV) - ELSE - CSTDV = '9999' - END IF - RSV2(3:4) = CSTDV(1:2) - RSV(1:2) = CSTDV(3:4) - - CALL UFBINT(LUNIT,UFBINT_8,1,1,IRET,'ACAV');ACAV=UFBINT_8 - IF(ACAV.LT.BMISS) THEN - WRITE(CSTDV(1:2),'(I2.2)') NINT(ACAV) - ELSE - CSTDV = '9999' - END IF - RSV2(1:2) = CSTDV(1:2) - - CALL S01O29(SID,XOB,YOB,RHR,RCH,RSV,RSV2,ELV,ITP,RTP) - - DO II = 1,NLCAT8 - IF(CF8(II).LT.BMISS) CALL S02O29(8,II,*9999) - ENDDO - -C PUT THE UNPACKED ON29 REPORT INTO OBS -C ------------------------------------- - - CALL S03O29(OBS,SUBSET,*9999,*9998) - - RETURN - 9999 CONTINUE - R07O29 = 999 - RETURN - 9998 CONTINUE - print'(" IW3UNP29/R07O29: RPT with ID= ",A," TOSSED - ZERO ", - $ "CAT.1-6,8,51,52 LVLS")', SID - R07O29 = -9999 - KSKSMI = KSKSMI + 1 - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: S06O29 MODIFIES AIRCRAFT ID -C PRGMMR: RAY CRAYTON ORG: W/NMC411 DATE: 1992-02-16 -C -C ABSTRACT: MODIFIES AMDAR REPORTS SO THAT LAST CHARACTER ENDS -C WITH 'Z'. -C -C PROGRAM HISTORY LOG: -C 1992-02-16 RAY CRAYTON -C -C USAGE: CALL S06O29(IDEN,ID) -C INPUT ARGUMENT LIST: -C IDEN - ACFT ID -C -C OUTPUT ARGUMENT LIST: -C ID - MODIFIED AIRCRAFT ID. -C -C REMARKS: -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - - SUBROUTINE S06O29(IDEN,ID) -C ---> formerly SUBROUTINE IDP - - CHARACTER*8 IDEN,ID - CHARACTER*6 ZEROES - CHARACTER*1 JCHAR - - SAVE - - DATA ZEROES/'000000'/ - - ID = ' ' - - L = INDEX(IDEN(1:8),' ') - IF(L.EQ.0) THEN - N = 8 - ELSE - N = L - 1 - IF(N.LT.1) THEN - ID = 'AMDARZ' - END IF - END IF - - IF(N.EQ.8) THEN - IF(IDEN(8:8).EQ.'Z') THEN - -C THE ID INDICATES IT IS AN 8-CHARACTER ASDAR REPORT. COMPRESS IT BY -C DELETING THE 6TH AND 7TH CHARACTER -C ------------------------------------------------------------------ - - ID = IDEN(1:5)//'Z' - GO TO 500 - END IF - END IF - - L = I05O29(IDEN(1:1),7,JCHAR) - - IF(L.EQ.0.OR.L.GT.6.OR.N.GT.6) THEN - -C UP THROUGH 6 CHARACTERS ARE LETTERS. CHANGE 6TH CHARACTER TO 'Z' -C --------------------------------------------------------------- - - IF(N.GE.5) THEN - ID = IDEN - ID(6:6) = 'Z' - ELSE - -C ZERO FILL AND ADD 'Z' TO MAKE 6 CHARAACTERS -C ------------------------------------------- - - ID = IDEN(1:N)//ZEROES(N+1:5)//'Z' - END IF - - ELSE IF(N.EQ.6) THEN - -C THE IDEN HAS 6 NUMERIC OR ALPHANUMERIC CHARACTERS -C ------------------------------------------------- - - IF(IDEN(6:6).EQ.'Z') THEN - ID = IDEN(1:6) - ELSE IF(L.GT.3) THEN - ID = IDEN(1:3)//IDEN(5:6)//'Z' - ELSE IF(L.EQ.1) THEN - ID = IDEN(2:6)//'Z' - ELSE - ID = IDEN(1:L-1)//IDEN(L+1:6)//'Z' - END IF - - ELSE IF(N.EQ.5) THEN - -C THE IDEN HAS 5 NUMERIC OR ALPHANUMERIC CHARACTERS -C ------------------------------------------------- - - ID = IDEN(1:5)//'Z' - ELSE - -C THE IDEN HAS 1-4 NUMERIC OR ALPHANUMERIC CHARACTERS -C --------------------------------------------------- - - IF(L.EQ.1) THEN - ID = ZEROES(1:5-N)//IDEN(1:N)//'Z' - ELSE - IF(N.LT.L) THEN - IDEN(1:6) = 'AMDARZ' - ELSE - ID = IDEN(1:L-1)// ZEROES(1:5-N)//IDEN(L:N)//'Z' - END IF - END IF - END IF - - 500 CONTINUE - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: I05O29 FINDS LOCATION OF NEXT NUMERIC -C PRGMMR: RAY CRAYTON ORG: W/NMC41 DATE: 1989-07-07 -C -C ABSTRACT: FINDS THE LOCATION OF THE NEXT NUMERIC CHARACTER -C IN A STRING OF CHARACTERS. -C -C PROGRAM HISTORY LOG: -C 1989-07-07 RAY CRAYTON -C -C USAGE: LOC=I05O29(STRING,NUM,CHAR) -C INPUT ARGUMENT LIST: -C STRING - CHARACTER ARRAY. -C NUM - NUMBER OF CHARACTERS TO SEARCH IN STRING. -C -C OUTPUT ARGUMENT LIST: -C I05O29 - INTEGER*4 LOCATION OF ALPHANUMERIC CHARACTER. -C = 0 IF NOT FOUND. -C CHAR - CHARACTER FOUND. -C -C REMARKS: NONE -C -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - FUNCTION I05O29(STRING,NUM,CHAR) -C ---> formerly FUNCTION IFIG - CHARACTER*1 STRING(1),CHAR - - SAVE - - DO I = 1,NUM - IF(STRING(I).GE.'0'.AND.STRING(I).LE.'9') THEN - I05O29 = I - CHAR = STRING(I) - GO TO 200 - END IF - ENDDO - I05O29 = 0 - CHAR = '?' - 200 CONTINUE - RETURN - END diff --git a/external/w3nco/v2.0.6/src/ixgb.f b/external/w3nco/v2.0.6/src/ixgb.f deleted file mode 100644 index 0645a3f93..000000000 --- a/external/w3nco/v2.0.6/src/ixgb.f +++ /dev/null @@ -1,155 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE IXGB(LUGB,LSKIP,LGRIB,NLEN,NNUM,MLEN,CBUF) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: IXGB MAKE INDEX RECORD -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 95-10-31 -C -C ABSTRACT: THIS SUBPROGRAM MAKES ONE INDEX RECORD. -C BYTE 001-004: BYTES TO SKIP IN DATA FILE BEFORE GRIB MESSAGE -C BYTE 005-008: BYTES TO SKIP IN MESSAGE BEFORE PDS -C BYTE 009-012: BYTES TO SKIP IN MESSAGE BEFORE GDS (0 IF NO GDS) -C BYTE 013-016: BYTES TO SKIP IN MESSAGE BEFORE BMS (0 IF NO BMS) -C BYTE 017-020: BYTES TO SKIP IN MESSAGE BEFORE BDS -C BYTE 021-024: BYTES TOTAL IN THE MESSAGE -C BYTE 025-025: GRIB VERSION NUMBER -C BYTE 026-053: PRODUCT DEFINITION SECTION (PDS) -C BYTE 054-095: GRID DEFINITION SECTION (GDS) (OR NULLS) -C BYTE 096-101: FIRST PART OF THE BIT MAP SECTION (BMS) (OR NULLS) -C BYTE 102-112: FIRST PART OF THE BINARY DATA SECTION (BDS) -C BYTE 113-172: (OPTIONAL) BYTES 41-100 OF THE PDS -C BYTE 173-184: (OPTIONAL) BYTES 29-40 OF THE PDS -C BYTE 185-320: (OPTIONAL) BYTES 43-178 OF THE GDS -C -C PROGRAM HISTORY LOG: -C 95-10-31 IREDELL -C 96-10-31 IREDELL AUGMENTED OPTIONAL DEFINITIONS TO BYTE 320 -C 2001-06-05 IREDELL APPLY LINUX PORT BY EBISUZAKI -C -C USAGE: CALL WRGI1R(LUGB,LSKIP,LGRIB,LUGI) -C INPUT ARGUMENTS: -C LUGB INTEGER LOGICAL UNIT OF INPUT GRIB FILE -C LSKIP INTEGER NUMBER OF BYTES TO SKIP BEFORE GRIB MESSAGE -C LGRIB INTEGER NUMBER OF BYTES IN GRIB MESSAGE -C NLEN INTEGER LENGTH OF EACH INDEX RECORD IN BYTES -C NNUM INTEGER INDEX RECORD NUMBER TO MAKE -C OUTPUT ARGUMENTS: -C MLEN INTEGER ACTUAL VALID LENGTH OF INDEX RECORD -C CBUF CHARACTER*1 (MBUF) BUFFER TO RECEIVE INDEX DATA -C -C SUBPROGRAMS CALLED: -C GBYTEC GET INTEGER DATA FROM BYTES -C SBYTEC STORE INTEGER DATA IN BYTES -C BAREAD BYTE-ADDRESSABLE READ -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - CHARACTER CBUF(*) - PARAMETER(LINDEX=112,MINDEX=320) - PARAMETER(IXSKP=0,IXSPD=4,IXSGD=8,IXSBM=12,IXSBD=16,IXLEN=20, - & IXVER=24,IXPDS=25,IXGDS=53,IXBMS=95,IXBDS=101, - & IXPDX=112,IXPDW=172,IXGDX=184) - PARAMETER(MXSKP=4,MXSPD=4,MXSGD=4,MXSBM=4,MXSBD=4,MXLEN=4, - & MXVER=1,MXPDS=28,MXGDS=42,MXBMS=6,MXBDS=11, - & MXPDX=60,MXPDW=12,MXGDX=136) - CHARACTER CBREAD(MINDEX),CINDEX(MINDEX) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C INITIALIZE INDEX RECORD AND READ GRIB MESSAGE - MLEN=LINDEX - CINDEX=CHAR(0) - CALL SBYTEC(CINDEX,LSKIP,8*IXSKP,8*MXSKP) - CALL SBYTEC(CINDEX,LGRIB,8*IXLEN,8*MXLEN) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PUT PDS IN INDEX RECORD - ISKPDS=8 - IBSKIP=LSKIP - IBREAD=ISKPDS+MXPDS - CALL BAREAD(LUGB,IBSKIP,IBREAD,LBREAD,CBREAD) - IF(LBREAD.NE.IBREAD) RETURN - CINDEX(IXVER+1)=CBREAD(8) - CALL SBYTEC(CINDEX,ISKPDS,8*IXSPD,8*MXSPD) - CALL GBYTEC(CBREAD,LENPDS,8*ISKPDS,8*3) - CALL GBYTEC(CBREAD,INCGDS,8*ISKPDS+8*7+0,1) - CALL GBYTEC(CBREAD,INCBMS,8*ISKPDS+8*7+1,1) - ILNPDS=MIN(LENPDS,MXPDS) - CINDEX(IXPDS+1:IXPDS+ILNPDS)=CBREAD(ISKPDS+1:ISKPDS+ILNPDS) - ISKTOT=ISKPDS+LENPDS -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PUT PDS EXTENSION IN INDEX RECORD - IF(LENPDS.GT.MXPDS) THEN - ISKPDW=ISKPDS+MXPDS - ILNPDW=MIN(LENPDS-MXPDS,MXPDW) - IBSKIP=LSKIP+ISKPDW - IBREAD=ILNPDW - CALL BAREAD(LUGB,IBSKIP,IBREAD,LBREAD,CBREAD) - IF(LBREAD.NE.IBREAD) RETURN - CINDEX(IXPDW+1:IXPDW+ILNPDW)=CBREAD(1:ILNPDW) - ISKPDX=ISKPDS+(MXPDS+MXPDW) - ILNPDX=MIN(LENPDS-(MXPDS+MXPDW),MXPDX) - IBSKIP=LSKIP+ISKPDX - IBREAD=ILNPDX - CALL BAREAD(LUGB,IBSKIP,IBREAD,LBREAD,CBREAD) - IF(LBREAD.NE.IBREAD) RETURN - CINDEX(IXPDX+1:IXPDX+ILNPDX)=CBREAD(1:ILNPDX) - MLEN=MAX(MLEN,IXPDW+ILNPDW,IXPDX+ILNPDX) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PUT GDS IN INDEX RECORD - IF(INCGDS.NE.0) THEN - ISKGDS=ISKTOT - IBSKIP=LSKIP+ISKGDS - IBREAD=MXGDS - CALL BAREAD(LUGB,IBSKIP,IBREAD,LBREAD,CBREAD) - IF(LBREAD.NE.IBREAD) RETURN - CALL SBYTEC(CINDEX,ISKGDS,8*IXSGD,8*MXSGD) - CALL GBYTEC(CBREAD,LENGDS,0,8*3) - ILNGDS=MIN(LENGDS,MXGDS) - CINDEX(IXGDS+1:IXGDS+ILNGDS)=CBREAD(1:ILNGDS) - ISKTOT=ISKGDS+LENGDS - IF(LENGDS.GT.MXGDS) THEN - ISKGDX=ISKGDS+MXGDS - ILNGDX=MIN(LENGDS-MXGDS,MXGDX) - IBSKIP=LSKIP+ISKGDX - IBREAD=ILNGDX - CALL BAREAD(LUGB,IBSKIP,IBREAD,LBREAD,CBREAD) - IF(LBREAD.NE.IBREAD) RETURN - CINDEX(IXGDX+1:IXGDX+ILNGDX)=CBREAD(1:ILNGDX) - MLEN=MAX(MLEN,IXGDX+ILNGDX) - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PUT BMS IN INDEX RECORD - IF(INCBMS.NE.0) THEN - ISKBMS=ISKTOT - IBSKIP=LSKIP+ISKBMS - IBREAD=MXBMS - CALL BAREAD(LUGB,IBSKIP,IBREAD,LBREAD,CBREAD) - IF(LBREAD.NE.IBREAD) RETURN - CALL SBYTEC(CINDEX,ISKBMS,8*IXSBM,8*MXSBM) - CALL GBYTEC(CBREAD,LENBMS,0,8*3) - ILNBMS=MIN(LENBMS,MXBMS) - CINDEX(IXBMS+1:IXBMS+ILNBMS)=CBREAD(1:ILNBMS) - ISKTOT=ISKBMS+LENBMS - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PUT BDS IN INDEX RECORD - ISKBDS=ISKTOT - IBSKIP=LSKIP+ISKBDS - IBREAD=MXBDS - CALL BAREAD(LUGB,IBSKIP,IBREAD,LBREAD,CBREAD) - IF(LBREAD.NE.IBREAD) RETURN - CALL SBYTEC(CINDEX,ISKBDS,8*IXSBD,8*MXSBD) - CALL GBYTEC(CBREAD,LENBDS,0,8*3) - ILNBDS=MIN(LENBDS,MXBDS) - CINDEX(IXBDS+1:IXBDS+ILNBDS)=CBREAD(1:ILNBDS) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C STORE INDEX RECORD - MLEN=MIN(MLEN,NLEN) - NSKIP=NLEN*(NNUM-1) - CBUF(NSKIP+1:NSKIP+MLEN)=CINDEX(1:MLEN) - CBUF(NSKIP+MLEN+1:NSKIP+NLEN)=CHAR(0) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/lengds.f b/external/w3nco/v2.0.6/src/lengds.f deleted file mode 100644 index 051aed69f..000000000 --- a/external/w3nco/v2.0.6/src/lengds.f +++ /dev/null @@ -1,40 +0,0 @@ -C----------------------------------------------------------------------- - FUNCTION LENGDS(KGDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: LENGDS RETURN THE LENGTH OF A GRID -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 96-07-19 -C -C ABSTRACT: GIVEN A GRID DESCRIPTION SECTION (IN W3FI63 FORMAT), -C RETURN ITS SIZE IN TERMS OF NUMBER OF DATA POINTS. -C -C PROGRAM HISTORY LOG: -C 96-07-19 IREDELL -C -C USAGE: CALL LENGDS(KGDS) -C INPUT ARGUMENTS: -C KGDS INTEGER (200) GDS PARAMETERS IN W3FI63 FORMAT -C OUTPUT ARGUMENTS: -C LENGDS INTEGER SIZE OF GRID -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN -C -C$$$ - INTEGER KGDS(200) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C SPECIAL CASE OF STAGGERED ETA - IF(KGDS(1).EQ.201) THEN - LENGDS=KGDS(7)*KGDS(8)-KGDS(8)/2 -C SPECIAL CASE OF FILLED ETA - ELSEIF(KGDS(1).EQ.202) THEN - LENGDS=KGDS(7)*KGDS(8) -C SPECIAL CASE OF THINNED WAFS - ELSEIF(KGDS(19).EQ.0.AND.KGDS(20).NE.255) THEN - LENGDS=KGDS(21) -C GENERAL CASE - ELSE - LENGDS=KGDS(2)*KGDS(3) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END diff --git a/external/w3nco/v2.0.6/src/makwmo.f b/external/w3nco/v2.0.6/src/makwmo.f deleted file mode 100644 index d8d4e0c35..000000000 --- a/external/w3nco/v2.0.6/src/makwmo.f +++ /dev/null @@ -1,89 +0,0 @@ - SUBROUTINE MAKWMO (BULHED,IDAY,IHOUR,KWBX,HEADER) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: MAKWMO FORMAT THE WMO HEADER -C PRGMMR: FARLEY ORG: W/NMC42 DATE: 84-07-06 -C -C ABSTRACT: FORMS THE WMO HEADER FOR A GIVEN BULLETIN. -C -C PROGRAM HISTORY LOG: -C 84-07-06 FARLEY ORIGINAL AUTHOR -C 94-10-10 R.E.JONES CHANGES FOR CRAY -C 95-10-18 R.E.JONES ADD PARAMETER KWBX TO CALL -C 98-06-16 Gilbert Changed argument list to pass in day and hour -C instead of the old O.N. 84 date word. -C 2003-03-28 Gilbert Removed equivalences. -C -C USAGE: CALL MAKWMO(BULHED,IDAY,IHOUR,KWBX,HEADER) -C INPUT ARGUMENT LIST: -C BULHED - TTAAII BULLETIN HEADER FT10 -C IDAY - Day of Month -C IHOUR - Hour of Day. -C KWBX - 4 CHARACTERS (KWBC TO KWBQ) -C -C OUTPUT ARGUMENT LIST: -C HEADER - COMPLETE WMO HEADER IN ASCII -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM SP -C -C$$$ -C - CHARACTER * 6 BULHED - CHARACTER * 1 HEADER (*) - CHARACTER * 1 WMOHDR (21) - CHARACTER * 4 KWBX - CHARACTER * 2 CTEMP -C -C-------------------------------------------------------------------- -C -C 1. CREATE WMO HEADER. -C -C 1.1 CONVERT BULHED FROM EBCDIC TO ASCII. -C -C WRITE (6,FMT='('' MADE IT TO MAKWMO'')') -C - DO I = 1,6 - WMOHDR(I) = BULHED(I:I) - END DO - WMOHDR(7)=char(32) ! ASCII BLANK -C -C MOVE KWBX INTO WMO HEADER -C - DO I = 1,4 - WMOHDR(I+7) = KWBX(I:I) - END DO - WMOHDR(12)=char(32) ! ASCII BLANK -C -C 1.2 PICK OFF THE DAY OF MONTH (YY) -C AND CONVERT TO ASCII. -C - write(ctemp,fmt='(I2.2)') IDAY - WMOHDR(13)=ctemp(1:1) - WMOHDR(14)=ctemp(2:2) -C -C 1.3 PICK OFF THE HOUR(GG) AND CONVERT TO ASCII. -C - write(ctemp,fmt='(I2.2)') IHOUR - WMOHDR(15)=ctemp(1:1) - WMOHDR(16)=ctemp(2:2) -C -C 1.4 FIL IN REST OF HEADER -C - WMOHDR(17)=char(48) ! ASCII "0" - WMOHDR(18)=char(48) ! ASCII "0" - WMOHDR(19)=char(13) ! ASCII CR = '\r' - WMOHDR(20)=char(13) ! ASCII CR = '\r' - WMOHDR(21)=char(10) ! ASCII LF = '\n' -C -C-------------------------------------------------------------------- -C -C 2. MOVE WMOHDR TO OUTPUT FIELD. -C - DO 200 I = 1,21 - HEADER(I) = WMOHDR(I) - 200 CONTINUE -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/mkfldsep.f b/external/w3nco/v2.0.6/src/mkfldsep.f deleted file mode 100644 index 706dd1b1c..000000000 --- a/external/w3nco/v2.0.6/src/mkfldsep.f +++ /dev/null @@ -1,105 +0,0 @@ - subroutine mkfldsep(csep,iopt,lenin,lenbull,lenout) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: mkfldsep Makes TOC Flag Field Separator Block -C PRGMMR: Gilbert ORG: W/NP11 DATE: 2002-09-16 -C -C ABSTRACT: Generates a TOC Flag Field Separator Block used to separate -C WMO Bulletins within a transmission file to be ingested in TOC's -C FTP Input Service, which can be used to disseminate WMO buletins. -C ( see http://weather.gov/tg/ftpingest.html ) -C -C This routine can generate different flag field separator blocks -C depending on the value of variable iopt. -C -C Bulletin "Flag Field Separator" block - OPTION 1 (old) -C bytes 1 - 4 marker string (####) -C 5 - 7 block length [018 fixed value] -C 8 - 13 total length of bulletin in bytes [octets] -C (not including the flag field block) -C 14 - 17 marker string (####) -C 18 line Feed (ASCII "0A") -C -C Bulletin "Flag Field Separator" block - OPTION 1a (new) -C bytes 1 - 4 marker string (####) -C 5 - 7 block length (nnn) - value always greater than 018 -C 8 - 18 total length of bulletin in bytes [octets] -C (not including the flag field block) -C 19 - nnn-5 reserved for future use -C nnn-4 - nnn-1 marker string (####) -C nnn line Feed (ASCII "0A") -C -C Bulletin "Flag Field Separator" block - OPTION 2 (limited) -C bytes 1 - 4 marker string (****) -C 5 - 14 total length of bulletin in bytes [octets] -C (not including the flag field block) -C 15 - 18 marker string (****) -C 19 line Feed (ASCII "0A") -C -C -C PROGRAM HISTORY LOG: -C 2002-09-16 Gilbert ORIGINAL AUTHOR -C -C USAGE: call mkfldsep(csep,iopt,lenin,lenbull,lenout) -C INPUT ARGUMENT LIST: -C iopt Flag Field Separator block option: -C = 1: Separator block for use with alphanumeric bulletins. -C if lenin <= 18 and lenbull <= 999999, -C OPTION 1 block will be generated. -C if lenin > 18 or lenbull > 999999, -C OPTION 1a block will be generated. -C = 2: Separator block for use with GRIB/BUFR bulletins. -C lenin Desired length of the flag field separator block. -C ignored, if iopt=2. -C lenbull Integer length of the bulletin (in bytes) that will follow -C this separator block. -C -C OUTPUT ARGUMENT LIST: -C csep*(*) Character array containing the flag field separator. -C lenout Integer length of the flag field separator block. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM/SP -C -C$$$ -C - character*(*),intent(out) :: csep - integer,intent(in) :: iopt,lenin,lenbull - integer,intent(out) :: lenout -C - character(len=4),parameter :: cstar='****',clb='####' -C - if (iopt.eq.1) then - if ( lenin .le. 18 .and. lenbull .le. 999999 ) then - ! Create OPTION 1 separator block - csep(1:4)=clb - csep(5:7)='018' - write(csep(8:13),fmt='(I6.6)') lenbull - csep(14:17)=clb - csep(18:18)=char(10) - lenout=18 - else ! Create OPTION 1a separator block - nnn=lenin - if ( nnn.lt.23 ) nnn=23 - csep(1:4)=clb - write(csep(5:7),fmt='(I3.3)') nnn - write(csep(8:18),fmt='(I11.11)') lenbull - csep(19:nnn-5)='0' - csep(nnn-4:nnn-1)=clb - csep(nnn:nnn)=char(10) - lenout=nnn - endif - elseif (iopt.eq.2) then ! Create OPTION 2 separator block - csep(1:4)=cstar - write(csep(5:14),fmt='(I10.10)') lenbull - csep(15:18)=cstar - csep(19:19)=char(10) - lenout=19 - else - print *,"mkfldsep: Option ",iopt," not recognized." - csep(1:lenin)=' ' - endif -C - return - end diff --git a/external/w3nco/v2.0.6/src/mova2i.c b/external/w3nco/v2.0.6/src/mova2i.c deleted file mode 100644 index 7627c9085..000000000 --- a/external/w3nco/v2.0.6/src/mova2i.c +++ /dev/null @@ -1,68 +0,0 @@ -/*$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: mova2i Moves a bit string from a char*1 to int -C PRGMMR: Gilbert ORG: W/NP11 DATE: 02-08-15 -C -C ABSTRACT: This Function copies a bit string from a Character*1 variable -C to an integer variable. It is intended to replace the Fortran Intrinsic -C Function ICHAR, which only supports 0 <= ICHAR(a) <= 127 on the -C IBM SP. If "a" is greater than 127 in the collating sequence, -C ICHAR(a) does not return the expected bit value. -C This function can be used for all values 0 <= ICHAR(a) <= 255. -C -C PROGRAM HISTORY LOG: -C 98-12-15 Gilbert -C -C USAGE: I = mova2i(a) -C -C INPUT ARGUMENT : -C -C a - Character*1 variable that holds the bitstring to extract -C -C RETURN ARGUMENT : -C -C mova2i - Integer value of the bitstring in character a -C -C REMARKS: -C -C None -C -C ATTRIBUTES: -C LANGUAGE: C -C MACHINE: IBM SP - -C -C$$$i*/ - -#ifdef CRAY90 - #include - int MOVA2I(unsigned char *a) -#endif -#ifdef HP - int mova2i(unsigned char *a) -#endif -#ifdef SGI - int mova2i_(unsigned char *a) -#endif -#ifdef MACOSX - int mova2i_(unsigned char *a) -#endif -#ifdef LINUX - int mova2i_(unsigned char *a) -#endif -#ifdef LINUXF90 - int MOVA2I(unsigned char *a) -#endif -#ifdef VPP5000 - int mova2i_(unsigned char *a) -#endif -#ifdef IBM4 - int mova2i(unsigned char *a) -#endif -#ifdef IBM8 - long long int mova2i(unsigned char *a) -#endif - -{ - return (int)(*a); -} diff --git a/external/w3nco/v2.0.6/src/pdsens.f b/external/w3nco/v2.0.6/src/pdsens.f deleted file mode 100644 index a50680261..000000000 --- a/external/w3nco/v2.0.6/src/pdsens.f +++ /dev/null @@ -1,76 +0,0 @@ -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: PDSENS.F PACKS GRIB PDS EXTENSION 41- FOR ENSEMBLE -C PRGMMR: RICHARD WOBUS ORG: W/NP20 DATE: 98-09-28 -C -C ABSTRACT: PACKS BRIB PDS EXTENSION STARTING ON BYTE 41 FOR ENSEMBLE -C FORECAST PRODUCTS. FOR FORMAT OF PDS EXTENSION, SEE NMC OFFICE NOTE 38 -C -C PROGRAM HISTORY LOG: -C 95-03-14 ZOLTAN TOTH AND MARK IREDELL -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-09-28 WOBUS CORRECTED MEMBER ENTRY, BLANK ALL UNUSED FIELDS -C 2001-06-05 IREDELL APPLY LINUX PORT BY EBISUZAKI -C -C USAGE: CALL PDSENS.F(KENS,KPROB,XPROB,KCLUST,KMEMBR,ILAST,MSGA) -C INPUT ARGUMENT LIST: -C KENS(5) - BYTES 41-45 (GENERAL SECTION, ALWAYS PRESENT.) -C KPROB(2) - BYTES 46-47 (PROBABILITY SECTION, PRESENT ONLY IF NEEDE -C XPROB(2) - BYTES 48-51&52-55 (PROBABILITY SECTION, IF NEEDED.) -C KCLUST(16)-BYTES 61-76 (CLUSTERING SECTION, IF NEEDED.) -C KMEMBR(80)-BYTES 77-86 (CLUSTER MEMBERSHIP SECTION, IF NEEDED.) -C ILAST - LAST BYTE TO BE PACKED (IF GREATER OR EQUAL TO FIRST BY -C IN ANY OF FOUR SECTIONS ABOVE, WHOLE SECTION IS PACKED. -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C MSGA - FULL PDS SECTION, INCLUDING NEW ENSEMBLE EXTENSION -C -C REMARKS: USE PDSEUP.F FOR UNPACKING PDS ENSEMBLE EXTENSION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ -C TESTING GRIB EXTENSION 41- PACKER AND UNPACKER SUBROUTINES -C -CFPP$ NOCONCUR R - SUBROUTINE PDSENS(KENS,KPROB,XPROB,KCLUST,KMEMBR,ILAST,MSGA) - INTEGER KENS(5),KPROB(2),KCLUST(16),KMEMBR(80) - DIMENSION XPROB(2) - CHARACTER*1 MSGA(100) - IF(ILAST.LT.41) THEN - GO TO 333 - ENDIF -C PACKING IS DONE IN FOUR SECTIONS ENDING AT BYTE IL - IF(ILAST.GE.41) IL=45 - IF(ILAST.GE.46) IL=55 - IF(ILAST.GE.61) IL=76 - IF(ILAST.GE.77) IL=86 - do i=42,il - CALL SBYTEC(MSGA, 0, i*8, 8) - enddo -C CHANGING THE NUMBER OF BYTES (FIRST THREE BYTES IN PDS) - CALL SBYTEC(MSGA, IL, 0,24) -C PACKING FIRST SECTION (GENERAL INTORMATION SECTION) - IF(IL.GE.45) CALL SBYTESC(MSGA,KENS,40*8,8,0,5) -C PACKING 2ND SECTION (PROBABILITY SECTION) - IF(IL.GE.55) THEN - CALL SBYTESC(MSGA,KPROB,45*8,8,0,2) - CALL W3FI01(LW) - CALL W3FI76(XPROB(1),IEXP,IMANT,8*LW) - CALL SBYTEC(MSGA,IEXP,47*8,8) - CALL SBYTEC(MSGA,IMANT,48*8,24) - CALL W3FI76(XPROB(2),IEXP,IMANT,8*LW) - CALL SBYTEC(MSGA,IEXP,51*8,8) - CALL SBYTEC(MSGA,IMANT,52*8,24) - ENDIF -C PACKING 3RD SECTION (CLUSTERING INFORMATION) - IF(IL.GE.76) CALL SBYTESC(MSGA,KCLUST,60*8,8,0,16) -C PACKING 4TH SECTION (CLUSTER MEMBERSHIP) - IF(IL.GE.86) CALL SBYTESC(MSGA,KMEMBR,76*8,1,0,80) -C - 333 CONTINUE - RETURN - END diff --git a/external/w3nco/v2.0.6/src/pdseup.f b/external/w3nco/v2.0.6/src/pdseup.f deleted file mode 100644 index 7127a2588..000000000 --- a/external/w3nco/v2.0.6/src/pdseup.f +++ /dev/null @@ -1,74 +0,0 @@ -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: PDSEUP.F UNPACKS GRIB PDS EXTENSION 41- FOR ENSEMBLE -C PRGMMR: RICHARD WOBUS ORG: W/NP20 DATE: 98-09-28 -C -C ABSTRACT: UNPACKS GRIB PDS EXTENSION STARTING ON BYTE 41 FOR ENSEMBLE -C FORECAST PRODUCTS. FOR FORMAT OF PDS EXTENSION, SEE NMC OFFICE NOTE 38 -C -C PROGRAM HISTORY LOG: -C 95-03-14 ZOLTAN TOTH AND MARK IREDELL -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-09-28 WOBUS CORRECTED MEMBER EXTRACTION -C 2001-06-05 IREDELL APPLY LINUX PORT BY EBISUZAKI -C -C USAGE: CALL PDSENS.F(KENS,KPROB,XPROB,KCLUST,KMEMBR,ILAST,MSGA) -C INPUT ARGUMENT LIST: -C ILAST - LAST BYTE TO BE UNPACKED (IF GREATER/EQUAL TO FIRST BYT -C IN ANY OF FOUR SECTIONS BELOW, WHOLE SECTION IS PACKED. -C MSGA - FULL PDS SECTION, INCLUDING NEW ENSEMBLE EXTENSION -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KENS(5) - BYTES 41-45 (GENERAL SECTION, ALWAYS PRESENT.) -C KPROB(2) - BYTES 46-47 (PROBABILITY SECTION, PRESENT ONLY IF NEEDE -C XPROB(2) - BYTES 48-51&52-55 (PROBABILITY SECTION, IF NEEDED.) -C KCLUST(16)-BYTES 61-76 (CLUSTERING SECTION, IF NEEDED.) -C KMEMBR(80)-BYTES 77-86 (CLUSTER MEMBERSHIP SECTION, IF NEEDED.) -C -C REMARKS: USE PDSENS.F FOR PACKING PDS ENSEMBLE EXTENSION. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: CF77 FORTRAN -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ -C - SUBROUTINE PDSEUP(KENS,KPROB,XPROB,KCLUST,KMEMBR,ILAST,MSGA) - INTEGER KENS(5),KPROB(2),KCLUST(16),KMEMBR(80) - DIMENSION XPROB(2) - CHARACTER*1 MSGA(100) -C CHECKING TOTAL NUMBER OF BYTES IN PDS (IBYTES) - CALL GBYTEC(MSGA, IBYTES, 0,24) - IF(ILAST.GT.IBYTES) THEN -C ILAST=IBYTES - GO TO 333 - ENDIF - IF(ILAST.LT.41) THEN - GO TO 333 - ENDIF -C UNPACKING FIRST SECTION (GENERAL INFORMATION) - CALL GBYTESC(MSGA,KENS,40*8,8,0,5) -C UNPACKING 2ND SECTION (PROBABILITY SECTION) - IF(ILAST.GE.46) THEN - CALL GBYTESC(MSGA,KPROB,45*8,8,0,2) -C - CALL GBYTEC (MSGA,JSGN,47*8,1) - CALL GBYTEC (MSGA,JEXP,47*8+1,7) - CALL GBYTEC (MSGA,IFR,47*8+8,24) - XPROB(1)=(-1)**JSGN*IFR*16.**(JEXP-70) -C - CALL GBYTEC (MSGA,JSGN,51*8,1) - CALL GBYTEC (MSGA,JEXP,51*8+1,7) - CALL GBYTEC (MSGA,IFR,51*8+8,24) - XPROB(2)=(-1)**JSGN*IFR*16.**(JEXP-70) - ENDIF -C -C UNPACKING 3RD SECTION (CLUSTERING INFORMATION) - IF(ILAST.GE.61) CALL GBYTESC(MSGA,KCLUST,60*8,8,0,16) -C UNPACKING 4TH SECTION (CLUSTERMEMBERSHIP INFORMATION) - IF(ILAST.GE.77) CALL GBYTESC(MSGA,KMEMBR,76*8,1,0,80) -C - 333 CONTINUE - RETURN - END diff --git a/external/w3nco/v2.0.6/src/putgb.f b/external/w3nco/v2.0.6/src/putgb.f deleted file mode 100644 index 072062dad..000000000 --- a/external/w3nco/v2.0.6/src/putgb.f +++ /dev/null @@ -1,201 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE PUTGB(LUGB,KF,KPDS,KGDS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: PUTGB PACKS AND WRITES A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: PACK AND WRITE A GRIB MESSAGE. -C THIS SUBPROGRAM IS NEARLY THE INVERSE OF GETGB. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 09-10-15 GAYNO INCREASED MAXBIT FROM 16 TO 32 -C -C USAGE: CALL PUTGB(LUGB,KF,KPDS,KGDS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C KF INTEGER NUMBER OF DATA POINTS -C KPDS INTEGER (200) PDS PARAMETERS -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C KGDS INTEGER (200) GDS PARAMETERS -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C LB LOGICAL*1 (KF) BITMAP IF PRESENT -C F REAL (KF) DATA -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C 0 ALL OK -C OTHER W3FI72 GRIB PACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C R63W72 MAP W3FI63 PARAMETERS ONTO W3FI72 PARAMETERS -C GETBIT GET NUMBER OF BITS AND ROUND DATA -C W3FI72 PACK GRIB -C WRYTE WRITE DATA -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER KPDS(200),KGDS(200) - LOGICAL*1 LB(KF) - REAL F(KF) - PARAMETER(MAXBIT=32) - INTEGER IBM(KF),IPDS(200),IGDS(200),IBDS(200) - REAL FR(KF) - CHARACTER PDS(400),GRIB(1000+KF*(MAXBIT+1)/8) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET W3FI72 PARAMETERS - CALL R63W72(KPDS,KGDS,IPDS,IGDS) - IBDS=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COUNT VALID DATA - KBM=KF - IF(IPDS(7).NE.0) THEN - KBM=0 - DO I=1,KF - IF(LB(I)) THEN - IBM(I)=1 - KBM=KBM+1 - ELSE - IBM(I)=0 - ENDIF - ENDDO - IF(KBM.EQ.KF) IPDS(7)=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET NUMBER OF BITS AND ROUND DATA - IF(KBM.EQ.0) THEN - DO I=1,KF - FR(I)=0. - ENDDO - NBIT=0 - ELSE - CALL GETBIT(IPDS(7),0,IPDS(25),KF,IBM,F,FR,FMIN,FMAX,NBIT) - NBIT=MIN(NBIT,MAXBIT) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PACK AND WRITE GRIB DATA - CALL W3FI72(0,FR,0,NBIT,0,IPDS,PDS, - & 1,255,IGDS,0,0,IBM,KF,IBDS, - & KFO,GRIB,LGRIB,IRET) - IF(IRET.EQ.0) CALL WRYTE(LUGB,LGRIB,GRIB) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/putgbe.f b/external/w3nco/v2.0.6/src/putgbe.f deleted file mode 100644 index 57b75673b..000000000 --- a/external/w3nco/v2.0.6/src/putgbe.f +++ /dev/null @@ -1,213 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE PUTGBE(LUGB,KF,KPDS,KGDS,KENS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: PUTGBE PACKS AND WRITES A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: PACK AND WRITE A GRIB MESSAGE. -C THIS SUBPROGRAM IS NEARLY THE INVERSE OF GETGBE. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL PUTGBE(LUGB,KF,KPDS,KGDS,KENS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C KF INTEGER NUMBER OF DATA POINTS -C KPDS INTEGER (200) PDS PARAMETERS -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C KGDS INTEGER (200) GDS PARAMETERS -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C KENS INTEGER (200) ENSEMBLE PDS PARMS -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C LB LOGICAL*1 (KF) BITMAP IF PRESENT -C F REAL (KF) DATA -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C 0 ALL OK -C OTHER W3FI72 GRIB PACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C R63W72 MAP W3FI63 PARAMETERS ONTO W3FI72 PARAMETERS -C GETBIT GET NUMBER OF BITS AND ROUND DATA -C W3FI72 PACK GRIB -C WRYTE WRITE DATA -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER KPDS(200),KGDS(200),KENS(200) - LOGICAL*1 LB(KF) - REAL F(KF) - PARAMETER(MAXBIT=16) - INTEGER IBM(KF),IPDS(200),IGDS(200),IBDS(200) - REAL FR(KF) - CHARACTER PDS(400),GRIB(1000+KF*(MAXBIT+1)/8) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET W3FI72 PARAMETERS - CALL R63W72(KPDS,KGDS,IPDS,IGDS) - IBDS=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COUNT VALID DATA - KBM=KF - IF(IPDS(7).NE.0) THEN - KBM=0 - DO I=1,KF - IF(LB(I)) THEN - IBM(I)=1 - KBM=KBM+1 - ELSE - IBM(I)=0 - ENDIF - ENDDO - IF(KBM.EQ.KF) IPDS(7)=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET NUMBER OF BITS AND ROUND DATA - IF(KBM.EQ.0) THEN - DO I=1,KF - FR(I)=0. - ENDDO - NBIT=0 - ELSE - CALL GETBIT(IPDS(7),0,IPDS(25),KF,IBM,F,FR,FMIN,FMAX,NBIT) - NBIT=MIN(NBIT,MAXBIT) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CREATE PRODUCT DEFINITION SECTION - CALL W3FI68(IPDS,PDS) - IF(IPDS(24).EQ.2) THEN - ILAST=45 - CALL PDSENS(KENS,KPROB,XPROB,KCLUST,KMEMBR,ILAST,PDS) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PACK AND WRITE GRIB DATA - CALL W3FI72(0,FR,0,NBIT,1,IPDS,PDS, - & 1,255,IGDS,0,0,IBM,KF,IBDS, - & KFO,GRIB,LGRIB,IRET) - IF(IRET.EQ.0) CALL WRYTE(LUGB,LGRIB,GRIB) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/putgben.f b/external/w3nco/v2.0.6/src/putgben.f deleted file mode 100644 index cdae86007..000000000 --- a/external/w3nco/v2.0.6/src/putgben.f +++ /dev/null @@ -1,223 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE PUTGBEN(LUGB,KF,KPDS,KGDS,KENS,IBS,NBITS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: PUTGBEN PACKS AND WRITES A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: PACK AND WRITE A GRIB MESSAGE. -C THIS SUBPROGRAM IS NEARLY THE INVERSE OF GETGBE. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 2001-03-16 IREDELL CORRECTED ARGUMENT LIST TO INCLUDE IBS -C -C USAGE: CALL PUTGBEN(LUGB,KF,KPDS,KGDS,KENS,IBS,NBITS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C KF INTEGER NUMBER OF DATA POINTS -C KPDS INTEGER (200) PDS PARAMETERS -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C KGDS INTEGER (200) GDS PARAMETERS -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C KENS INTEGER (200) ENSEMBLE PDS PARMS -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C IBS INTEGER BINARY SCALE FACTOR (0 TO IGNORE) -C NBITS INTEGER NUMBER OF BITS IN WHICH TO PACK (0 TO IGNORE) -C LB LOGICAL*1 (KF) BITMAP IF PRESENT -C F REAL (KF) DATA -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C 0 ALL OK -C OTHER W3FI72 GRIB PACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C R63W72 MAP W3FI63 PARAMETERS ONTO W3FI72 PARAMETERS -C GETBIT GET NUMBER OF BITS AND ROUND DATA -C W3FI72 PACK GRIB -C WRYTE WRITE DATA -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER KPDS(200),KGDS(200),KENS(200) - LOGICAL*1 LB(KF) - REAL F(KF) - PARAMETER(MAXBIT=16) - INTEGER IBM(KF),IPDS(200),IGDS(200),IBDS(200) - REAL FR(KF) - CHARACTER PDS(400),GRIB(1000+KF*(MAXBIT+1)/8) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET W3FI72 PARAMETERS - CALL R63W72(KPDS,KGDS,IPDS,IGDS) - IBDS=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COUNT VALID DATA - KBM=KF - IF(IPDS(7).NE.0) THEN - KBM=0 - DO I=1,KF - IF(LB(I)) THEN - IBM(I)=1 - KBM=KBM+1 - ELSE - IBM(I)=0 - ENDIF - ENDDO - IF(KBM.EQ.KF) IPDS(7)=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET NUMBER OF BITS AND ROUND DATA - IF(NBITS.GT.0) THEN - DO I=1,KF - FR(I)=F(I) - ENDDO - NBIT=NBITS - ELSE - IF(KBM.EQ.0) THEN - DO I=1,KF - FR(I)=0. - ENDDO - NBIT=0 - ELSE - CALL GETBIT(IPDS(7),IBS,IPDS(25),KF,IBM,F,FR,FMIN,FMAX,NBIT) - NBIT=MIN(NBIT,MAXBIT) - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CREATE PRODUCT DEFINITION SECTION - CALL W3FI68(IPDS,PDS) - IF(IPDS(24).EQ.2) THEN - ILAST=45 - CALL PDSENS(KENS,KPROB,XPROB,KCLUST,KMEMBR,ILAST,PDS) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PACK AND WRITE GRIB DATA - CALL W3FI72(0,FR,0,NBIT,1,IPDS,PDS, - & 1,255,IGDS,0,0,IBM,KF,IBDS, - & KFO,GRIB,LGRIB,IRET) - IF(IRET.EQ.0) CALL WRYTE(LUGB,LGRIB,GRIB) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/putgbex.f b/external/w3nco/v2.0.6/src/putgbex.f deleted file mode 100644 index f21413e44..000000000 --- a/external/w3nco/v2.0.6/src/putgbex.f +++ /dev/null @@ -1,222 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE PUTGBEX(LUGB,KF,KPDS,KGDS,KENS, - & KPROB,XPROB,KCLUST,KMEMBR,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: PUTGBE PACKS AND WRITES A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: PACK AND WRITE A GRIB MESSAGE. -C THIS SUBPROGRAM IS NEARLY THE INVERSE OF GETGBE. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 97-02-11 Y.ZHU INCLUDED PROBABILITY AND CLUSTER ARGUMENTS -C -C USAGE: CALL PUTGBE(LUGB,KF,KPDS,KGDS,KENS, -C & KPROB,XPROB,KCLUST,KMEMBR,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C KF INTEGER NUMBER OF DATA POINTS -C KPDS INTEGER (200) PDS PARAMETERS -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C KGDS INTEGER (200) GDS PARAMETERS -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C KENS INTEGER (200) ENSEMBLE PDS PARMS -C (1) - APPLICATION IDENTIFIER -C (2) - ENSEMBLE TYPE -C (3) - ENSEMBLE IDENTIFIER -C (4) - PRODUCT IDENTIFIER -C (5) - SMOOTHING FLAG -C KPROB INTEGER (2) PROBABILITY ENSEMBLE PARMS -C XPROB REAL (2) PROBABILITY ENSEMBLE PARMS -C KCLUST INTEGER (16) CLUSTER ENSEMBLE PARMS -C KMEMBR INTEGER (8) CLUSTER ENSEMBLE PARMS -C LB LOGICAL*1 (KF) BITMAP IF PRESENT -C F REAL (KF) DATA -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C 0 ALL OK -C OTHER W3FI72 GRIB PACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C R63W72 MAP W3FI63 PARAMETERS ONTO W3FI72 PARAMETERS -C GETBIT GET NUMBER OF BITS AND ROUND DATA -C W3FI72 PACK GRIB -C WRYTE WRITE DATA -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER KPDS(200),KGDS(200),KENS(200) - INTEGER KPROB(2),KCLUST(16),KMEMBR(80) - REAL XPROB(2) - LOGICAL*1 LB(KF) - REAL F(KF) - PARAMETER(MAXBIT=16) - INTEGER IBM(KF),IPDS(200),IGDS(200),IBDS(200) - REAL FR(KF) - CHARACTER PDS(400),GRIB(1000+KF*(MAXBIT+1)/8) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET W3FI72 PARAMETERS - CALL R63W72(KPDS,KGDS,IPDS,IGDS) - IBDS=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COUNT VALID DATA - KBM=KF - IF(IPDS(7).NE.0) THEN - KBM=0 - DO I=1,KF - IF(LB(I)) THEN - IBM(I)=1 - KBM=KBM+1 - ELSE - IBM(I)=0 - ENDIF - ENDDO - IF(KBM.EQ.KF) IPDS(7)=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET NUMBER OF BITS AND ROUND DATA - IF(KBM.EQ.0) THEN - DO I=1,KF - FR(I)=0. - ENDDO - NBIT=0 - ELSE - CALL GETBIT(IPDS(7),0,IPDS(25),KF,IBM,F,FR,FMIN,FMAX,NBIT) - NBIT=MIN(NBIT,MAXBIT) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C CREATE PRODUCT DEFINITION SECTION - CALL W3FI68(IPDS,PDS) - IF(IPDS(24).EQ.2) THEN - ILAST=86 - CALL PDSENS(KENS,KPROB,XPROB,KCLUST,KMEMBR,ILAST,PDS) - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PACK AND WRITE GRIB DATA - CALL W3FI72(0,FR,0,NBIT,1,IPDS,PDS, - & 1,255,IGDS,0,0,IBM,KF,IBDS, - & KFO,GRIB,LGRIB,IRET) - IF(IRET.EQ.0) CALL WRYTE(LUGB,LGRIB,GRIB) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/putgbn.f b/external/w3nco/v2.0.6/src/putgbn.f deleted file mode 100644 index 671f1106b..000000000 --- a/external/w3nco/v2.0.6/src/putgbn.f +++ /dev/null @@ -1,209 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE PUTGBN(LUGB,KF,KPDS,KGDS,IBS,NBITS,LB,F,IRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: PUTGBN PACKS AND WRITES A GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 94-04-01 -C -C ABSTRACT: PACK AND WRITE A GRIB MESSAGE. -C THIS SUBPROGRAM IS NEARLY THE INVERSE OF GETGB. -C -C PROGRAM HISTORY LOG: -C 94-04-01 IREDELL -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL PUTGBN(LUGB,KF,KPDS,KGDS,NBITS,LB,F,IRET) -C INPUT ARGUMENTS: -C LUGB INTEGER UNIT OF THE UNBLOCKED GRIB DATA FILE -C KF INTEGER NUMBER OF DATA POINTS -C KPDS INTEGER (200) PDS PARAMETERS -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C KGDS INTEGER (200) GDS PARAMETERS -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C IBS INTEGER BINARY SCALE FACTOR (0 TO IGNORE) -C NBITS INTEGER NUMBER OF BITS IN WHICH TO PACK (0 TO IGNORE) -C LB LOGICAL*1 (KF) BITMAP IF PRESENT -C F REAL (KF) DATA -C OUTPUT ARGUMENTS: -C IRET INTEGER RETURN CODE -C 0 ALL OK -C OTHER W3FI72 GRIB PACKER RETURN CODE -C -C SUBPROGRAMS CALLED: -C R63W72 MAP W3FI63 PARAMETERS ONTO W3FI72 PARAMETERS -C GETBIT GET NUMBER OF BITS AND ROUND DATA -C W3FI72 PACK GRIB -C WRYTE WRITE DATA -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C DO NOT ENGAGE THE SAME LOGICAL UNIT FROM MORE THAN ONE PROCESSOR. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ - INTEGER KPDS(200),KGDS(200) - LOGICAL*1 LB(KF) - REAL F(KF) - PARAMETER(MAXBIT=16) - INTEGER IBM(KF),IPDS(200),IGDS(200),IBDS(200) - REAL FR(KF) - CHARACTER PDS(400),GRIB(1000+KF*(MAXBIT+1)/8) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET W3FI72 PARAMETERS - CALL R63W72(KPDS,KGDS,IPDS,IGDS) - IBDS=0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C COUNT VALID DATA - KBM=KF - IF(IPDS(7).NE.0) THEN - KBM=0 - DO I=1,KF - IF(LB(I)) THEN - IBM(I)=1 - KBM=KBM+1 - ELSE - IBM(I)=0 - ENDIF - ENDDO - IF(KBM.EQ.KF) IPDS(7)=0 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C GET NUMBER OF BITS AND ROUND DATA - IF(NBITS.GT.0) THEN - DO I=1,KF - FR(I)=F(I) - ENDDO - NBIT=NBITS - ELSE - IF(KBM.EQ.0) THEN - DO I=1,KF - FR(I)=0. - ENDDO - NBIT=0 - ELSE - CALL GETBIT(IPDS(7),IBS,IPDS(25),KF,IBM,F,FR,FMIN,FMAX,NBIT) - NBIT=MIN(NBIT,MAXBIT) - ENDIF - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C PACK AND WRITE GRIB DATA - CALL W3FI72(0,FR,0,NBIT,0,IPDS,PDS, - & 1,255,IGDS,0,0,IBM,KF,IBDS, - & KFO,GRIB,LGRIB,IRET) - IF(IRET.EQ.0) CALL WRYTE(LUGB,LGRIB,GRIB) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/q9ie32.f b/external/w3nco/v2.0.6/src/q9ie32.f deleted file mode 100644 index 09596b45f..000000000 --- a/external/w3nco/v2.0.6/src/q9ie32.f +++ /dev/null @@ -1,139 +0,0 @@ - SUBROUTINE Q9IE32(A,B,N,ISTAT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: Q9IE32 CONVERT IBM370 F.P. TO IEEE F.P. -C PRGMMR: R.E.JONES ORG: W/NMC42 DATE: 90-06-04 -C -C ABSTRACT: CONVERT IBM370 32 BIT FLOATING POINT NUMBERS TO IEEE -C 32 BIT TASK 754 FLOATING POINT NUMBERS. -C -C PROGRAM HISTORY LOG: -C 90-06-04 R.E.JONES CHANGE TO SUN FORTRAN 1.3 -C 90-07-14 R.E.JONES CHANGE ISHFT TO LSHIFT OR LRSHFT -C 91-03-09 R.E.JONES CHANGE TO SiliconGraphics FORTRAN -C 92-07-20 R.E.JONES CHANGE TO IBM AIX XL FORTRAN -C 95-11-15 R.E.JONES ADD SAVE STATEMENT -C 98-11-15 gilbert Specified 4-byte integers for IBM SP -C -C USAGE: CALL Q9IE32(A, B, N, ISTAT) -C INPUT ARGUMENT LIST: -C A - REAL*4 ARRAY OF IBM370 32 BIT FLOATING POINT NUMBERS -C N - NUMBER OF POINTS TO CONVERT -C -C OUTPUT ARGUMENT LIST: -C B - REAL*4 ARRAY OF IEEE 32 BIT FLOATING POINT NUMBERS -C ISTAT - NUMBER OF POINT GREATER THAN 10E+38, NUMBERS ARE SET TO -C IEEE INFINITY, ONE IS ADDED TO ISTAT. NUMBERS LESS THAN -C E-38 ARE SET TO ZERO , ONE IS NOT ADDED TO ISTAT. -C -C REMARKS: SEE IEEE TASK 754 STANDARD FLOATING POINT ARITHMETIC -C FOR MORE INFORMATION ABOUT IEEE F.P. -C -C ATTRIBUTES: -C LANGUAGE: IBM AIX XL FORTRAN Compiler/6000 -C MACHINE: IBM RS6000 model 530 -C -C$$$ -C - INTEGER(4) A(*) - INTEGER(4) B(*) - INTEGER(4) SIGN - INTEGER(4) INFIN,MASKFR,MASKSN,MASK21,MASK22,MASK23 - INTEGER(4) ITEMP,ISIGN,IEEEXP,K,LTEMP -C - SAVE -C - DATA INFIN /Z'7F800000'/ - DATA MASKFR/Z'007FFFFF'/ - DATA MASKSN/Z'7FFFFFFF'/ - DATA MASK21/Z'00200000'/ - DATA MASK22/Z'00400000'/ - DATA MASK23/Z'00800000'/ - DATA SIGN /Z'80000000'/ -C - IF (N.LT.1) THEN - ISTAT = -1 - RETURN - ENDIF -C - ISTAT = 0 -C - DO 40 I = 1,N - ISIGN = 0 - ITEMP = A(I) -C -C TEST SIGN BIT -C - IF (ITEMP.EQ.0) GO TO 30 -C - IF (ITEMP.LT.0) THEN -C - ISIGN = SIGN -C -C SET SIGN BIT TO ZERO -C - ITEMP = IAND(ITEMP,MASKSN) -C - END IF -C -C -C CONVERT IBM EXPONENT TO IEEE EXPONENT -C - IEEEXP = (ISHFT(ITEMP,-24_4) - 64_4) * 4 + 126 -C - K = 0 -C -C TEST BIT 23, 22, 21 -C ADD UP NUMBER OF ZERO BITS IN FRONT OF IBM370 FRACTION -C - IF (IAND(ITEMP,MASK23).NE.0) GO TO 10 - K = K + 1 - IF (IAND(ITEMP,MASK22).NE.0) GO TO 10 - K = K + 1 - IF (IAND(ITEMP,MASK21).NE.0) GO TO 10 - K = K + 1 -C - 10 CONTINUE -C -C SUBTRACT ZERO BITS FROM EXPONENT -C - IEEEXP = IEEEXP - K -C -C TEST FOR OVERFLOW -C - IF (IEEEXP.GT.254) GO TO 20 -C -C TEST FOR UNDERFLOW -C - IF (IEEEXP.LT.1) GO TO 30 -C -C SHIFT IEEE EXPONENT TO BITS 1 TO 8 -C - LTEMP = ISHFT(IEEEXP,23_4) -C -C SHIFT IBM370 FRACTION LEFT K BIT, AND OUT BITS 0 - 8 -C OR TOGETHER THE EXPONENT AND THE FRACTION -C OR IN SIGN BIT -C - B(I) = IOR(IOR(IAND(ISHFT(ITEMP,K),MASKFR),LTEMP),ISIGN) -C - GO TO 40 -C - 20 CONTINUE -C -C OVERFLOW , SET TO IEEE INFINITY, ADD 1 TO OVERFLOW COUNTER -C - ISTAT = ISTAT + 1 - B(I) = IOR(INFIN,ISIGN) - GO TO 40 -C - 30 CONTINUE -C -C UNDERFLOW , SET TO ZERO -C - B(I) = 0 -C - 40 CONTINUE -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/r63w72.f b/external/w3nco/v2.0.6/src/r63w72.f deleted file mode 100644 index 4d52ab96a..000000000 --- a/external/w3nco/v2.0.6/src/r63w72.f +++ /dev/null @@ -1,125 +0,0 @@ - SUBROUTINE R63W72(KPDS,KGDS,IPDS,IGDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: R63W72 CONVERT W3FI63 PARMS TO W3FI72 PARMS -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 92-10-31 -C -C ABSTRACT: DETERMINES THE INTEGER PDS AND GDS PARAMETERS -C FOR THE GRIB1 PACKING ROUTINE W3FI72 GIVEN THE PARAMETERS -C RETURNED FROM THE GRIB1 UNPACKING ROUTINE W3FI63. -C -C PROGRAM HISTORY LOG: -C 91-10-31 MARK IREDELL -C 96-05-03 MARK IREDELL CORRECTED SOME LEVEL TYPES AND -C SOME DATA REPRESENTATION TYPES -C 97-02-14 MARK IREDELL ONLY ALTERED IPDS(26:27) FOR EXTENDED PDS -C 98-06-01 CHRIS CARUSO Y2K FIX FOR YEAR OF CENTURY -C 2005-05-06 DIANE STOKES RECOGNIZE LEVEL 236 -C -C USAGE: CALL R63W72(KPDS,KGDS,IPDS,IGDS) -C -C INPUT ARGUMENT LIST: -C KPDS - INTEGER (200) PDS PARAMETERS FROM W3FI63 -C KGDS - INTEGER (200) GDS PARAMETERS FROM W3FI63 -C -C OUTPUT ARGUMENT LIST: -C IPDS - INTEGER (200) PDS PARAMETERS FOR W3FI72 -C IGDS - INTEGER (200) GDS PARAMETERS FOR W3FI72 -C -C REMARKS: KGDS AND IGDS EXTEND BEYOND THEIR DIMENSIONS HERE -C IF PL PARAMETERS ARE PRESENT. -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN -C -C$$$ - DIMENSION KPDS(200),KGDS(200),IPDS(200),IGDS(200) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE PRODUCT DEFINITION SECTION (PDS) PARAMETERS - IF(KPDS(23).NE.2) THEN - IPDS(1)=28 ! LENGTH OF PDS - ELSE - IPDS(1)=45 ! LENGTH OF PDS - ENDIF - IPDS(2)=KPDS(19) ! PARAMETER TABLE VERSION - IPDS(3)=KPDS(1) ! ORIGINATING CENTER - IPDS(4)=KPDS(2) ! GENERATING MODEL - IPDS(5)=KPDS(3) ! GRID DEFINITION - IPDS(6)=MOD(KPDS(4)/128,2) ! GDS FLAG - IPDS(7)=MOD(KPDS(4)/64,2) ! BMS FLAG - IPDS(8)=KPDS(5) ! PARAMETER INDICATOR - IPDS(9)=KPDS(6) ! LEVEL TYPE - IF(KPDS(6).EQ.101.OR.KPDS(6).EQ.104.OR.KPDS(6).EQ.106.OR. - & KPDS(6).EQ.108.OR.KPDS(6).EQ.110.OR.KPDS(6).EQ.112.OR. - & KPDS(6).EQ.114.OR.KPDS(6).EQ.116.OR.KPDS(6).EQ.121.OR. - & KPDS(6).EQ.128.OR.KPDS(6).EQ.141.OR.KPDS(6).EQ.236) THEN - IPDS(10)=MOD(KPDS(7)/256,256) ! LEVEL VALUE 1 - IPDS(11)=MOD(KPDS(7),256) ! LEVEL VALUE 2 - ELSE - IPDS(10)=0 ! LEVEL VALUE 1 - IPDS(11)=KPDS(7) ! LEVEL VALUE 2 - ENDIF - IPDS(12)=KPDS(8) ! YEAR OF CENTURY - IPDS(13)=KPDS(9) ! MONTH - IPDS(14)=KPDS(10) ! DAY - IPDS(15)=KPDS(11) ! HOUR - IPDS(16)=KPDS(12) ! MINUTE - IPDS(17)=KPDS(13) ! FORECAST TIME UNIT - IPDS(18)=KPDS(14) ! TIME RANGE 1 - IPDS(19)=KPDS(15) ! TIME RANGE 2 - IPDS(20)=KPDS(16) ! TIME RANGE INDICATOR - IPDS(21)=KPDS(17) ! NUMBER IN AVERAGE - IPDS(22)=KPDS(20) ! NUMBER MISSING IN AVERAGE - IPDS(23)=KPDS(21) ! CENTURY - IPDS(24)=KPDS(23) ! SUBCENTER - IPDS(25)=KPDS(22) ! DECIMAL SCALING - IF(IPDS(1).GT.28) THEN - IPDS(26)=0 ! PDS BYTE 29 - IPDS(27)=0 ! PDS BYTE 30 - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C DETERMINE GRID DEFINITION SECTION (GDS) PARAMETERS - IGDS(1)=KGDS(19) ! NUMBER OF VERTICAL COORDINATES - IGDS(2)=KGDS(20) ! VERTICAL COORDINATES - IGDS(3)=KGDS(1) ! DATA REPRESENTATION - IGDS(4)=KGDS(2) ! (UNIQUE TO REPRESENTATION) - IGDS(5)=KGDS(3) ! (UNIQUE TO REPRESENTATION) - IGDS(6)=KGDS(4) ! (UNIQUE TO REPRESENTATION) - IGDS(7)=KGDS(5) ! (UNIQUE TO REPRESENTATION) - IGDS(8)=KGDS(6) ! (UNIQUE TO REPRESENTATION) - IGDS(9)=KGDS(7) ! (UNIQUE TO REPRESENTATION) - IGDS(10)=KGDS(8) ! (UNIQUE TO REPRESENTATION) - IGDS(11)=KGDS(9) ! (UNIQUE TO REPRESENTATION) - IGDS(12)=KGDS(10) ! (UNIQUE TO REPRESENTATION) - IGDS(13)=KGDS(11) ! (UNIQUE TO REPRESENTATION) - IGDS(14)=KGDS(12) ! (UNIQUE TO REPRESENTATION) - IGDS(15)=KGDS(13) ! (UNIQUE TO REPRESENTATION) - IGDS(16)=KGDS(14) ! (UNIQUE TO REPRESENTATION) - IGDS(17)=KGDS(15) ! (UNIQUE TO REPRESENTATION) - IGDS(18)=KGDS(16) ! (UNIQUE TO REPRESENTATION) -C EXCEPTIONS FOR LATLON OR GAUSSIAN - IF(KGDS(1).EQ.0.OR.KGDS(1).EQ.4) THEN - IGDS(11)=KGDS(10) - IGDS(12)=KGDS(9) -C EXCEPTIONS FOR MERCATOR - ELSEIF(KGDS(1).EQ.1) THEN - IGDS(11)=KGDS(13) - IGDS(12)=KGDS(12) - IGDS(13)=KGDS(9) - IGDS(14)=KGDS(11) -C EXCEPTIONS FOR LAMBERT CONFORMAL - ELSEIF(KGDS(1).EQ.3) THEN - IGDS(15)=KGDS(12) - IGDS(16)=KGDS(13) - IGDS(17)=KGDS(14) - IGDS(18)=KGDS(15) - ENDIF -C EXTENSION FOR PL PARAMETERS - IF(KGDS(1).EQ.0.AND.KGDS(19).EQ.0.AND.KGDS(20).NE.255) THEN - DO J=1,KGDS(3) - IGDS(18+J)=KGDS(21+J) - ENDDO - ENDIF -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/sbyte.f b/external/w3nco/v2.0.6/src/sbyte.f deleted file mode 100644 index df958fd0b..000000000 --- a/external/w3nco/v2.0.6/src/sbyte.f +++ /dev/null @@ -1,79 +0,0 @@ - SUBROUTINE SBYTE(IOUT,IN,ISKIP,NBYTE) -C THIS PROGRAM WRITTEN BY..... -C DR. ROBERT C. GAMMILL, CONSULTANT -C NATIONAL CENTER FOR ATMOSPHERIC RESEARCH -C JULY 1972 -C -C THIS IS THE FORTRAN 32 bit VERSION OF SBYTE. -C Changes for SiliconGraphics IRIS-4D/25 -C SiliconGraphics 3.3 FORTRAN 77 -C MARCH 1991 RUSSELL E. JONES -C NATIONAL WEATHER SERVICE -C - INTEGER IN - INTEGER IOUT(*) - INTEGER MASKS(32) -C - SAVE -C - DATA NBITSW/32/ -C -C DATA MASKS /Z'00000001',Z'00000003',Z'00000007',Z'0000000F', -C & Z'0000001F',Z'0000003F',Z'0000007F',Z'000000FF', -C & Z'000001FF',Z'000003FF',Z'000007FF',Z'00000FFF', -C & Z'00001FFF',Z'00003FFF',Z'00007FFF',Z'0000FFFF', -C & Z'0001FFFF',Z'0003FFFF',Z'0007FFFF',Z'000FFFFF', -C & Z'001FFFFF',Z'003FFFFF',Z'007FFFFF',Z'00FFFFFF', -C & Z'01FFFFFF',Z'03FFFFFF',Z'07FFFFFF',Z'0FFFFFFF', -C & Z'1FFFFFFF',Z'3FFFFFFF',Z'7FFFFFFF',Z'FFFFFFFF'/ -C -C MASK TABLE PUT IN DECIMAL SO IT WILL COMPILE ON AN 32 BIT -C COMPUTER -C - DATA MASKS / 1, 3, 7, 15, 31, 63, 127, 255, 511, 1023, 2047, - & 4095, 8191, 16383, 32767, 65535, 131071, 262143, 524287, - & 1048575, 2097151, 4194303, 8388607, 16777215, 33554431, - & 67108863, 134217727, 268435455, 536870911, 1073741823, - & 2147483647, -1/ -C -C NBYTE MUST BE LESS THAN OR EQUAL TO NBITSW -C - ICON = NBITSW - NBYTE - IF (ICON.LT.0) RETURN - MASK = MASKS(NBYTE) -C -C INDEX TELLS HOW MANY WORDS INTO IOUT THE NEXT BYTE IS TO BE STORED. -C - INDEX = ISHFT(ISKIP,-5) -C -C II TELLS HOW MANY BITS IN FROM THE LEFT SIDE OF THE WORD TO STORE IT. -C - II = MOD(ISKIP,NBITSW) -C - J = IAND(MASK,IN) - MOVEL = ICON - II -C -C BYTE IS TO BE STORED IN MIDDLE OF WORD. SHIFT LEFT. -C - IF (MOVEL.GT.0) THEN - MSK = ISHFT(MASK,MOVEL) - IOUT(INDEX+1) = IOR(IAND(NOT(MSK),IOUT(INDEX+1)), - & ISHFT(J,MOVEL)) -C -C THE BYTE IS TO BE SPLIT ACROSS A WORD BREAK. -C - ELSE IF (MOVEL.LT.0) THEN - MSK = MASKS(NBYTE+MOVEL) - IOUT(INDEX+1) = IOR(IAND(NOT(MSK),IOUT(INDEX+1)), - & ISHFT(J,MOVEL)) - ITEMP = IAND(MASKS(NBITSW+MOVEL),IOUT(INDEX+2)) - IOUT(INDEX+2) = IOR(ITEMP,ISHFT(J,NBITSW+MOVEL)) -C -C BYTE IS TO BE STORED RIGHT-ADJUSTED. -C - ELSE - IOUT(INDEX+1) = IOR(IAND(NOT(MASK),IOUT(INDEX+1)),J) - ENDIF -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/sbytec.f b/external/w3nco/v2.0.6/src/sbytec.f deleted file mode 100644 index 042b1f669..000000000 --- a/external/w3nco/v2.0.6/src/sbytec.f +++ /dev/null @@ -1,6 +0,0 @@ - SUBROUTINE SBYTEC(OUT,IN,ISKIP,NBYTE) - character*1 out(*) - integer in(*) - CALL SBYTESC(OUT,IN,ISKIP,NBYTE,0,1) - RETURN - END diff --git a/external/w3nco/v2.0.6/src/sbytes.f b/external/w3nco/v2.0.6/src/sbytes.f deleted file mode 100644 index 5a1490675..000000000 --- a/external/w3nco/v2.0.6/src/sbytes.f +++ /dev/null @@ -1,101 +0,0 @@ - SUBROUTINE SBYTES(IOUT,IN,ISKIP,NBYTE,NSKIP,N) -C THIS PROGRAM WRITTEN BY..... -C DR. ROBERT C. GAMMILL, CONSULTANT -C NATIONAL CENTER FOR ATMOSPHERIC RESEARCH -C JULY 1972 -C THIS IS THE FORTRAN VERSIONS OF SBYTES. -C -C Changes for SiliconGraphics IRIS-4D/25 -C SiliconGraphics 3.3 FORTRAN 77 -C March 1991 RUSSELL E. JONES -C NATIONAL WEATHER SERVICE -C - INTEGER IN(*) - INTEGER IOUT(*) - INTEGER MASKS(32) -C - SAVE -C - DATA NBITSW/32/ -C -C DATA MASKS /Z'00000001',Z'00000003',Z'00000007',Z'0000000F', -C & Z'0000001F',Z'0000003F',Z'0000007F',Z'000000FF', -C & Z'000001FF',Z'000003FF',Z'000007FF',Z'00000FFF', -C & Z'00001FFF',Z'00003FFF',Z'00007FFF',Z'0000FFFF', -C & Z'0001FFFF',Z'0003FFFF',Z'0007FFFF',Z'000FFFFF', -C & Z'001FFFFF',Z'003FFFFF',Z'007FFFFF',Z'00FFFFFF', -C & Z'01FFFFFF',Z'03FFFFFF',Z'07FFFFFF',Z'0FFFFFFF', -C & Z'1FFFFFFF',Z'3FFFFFFF',Z'7FFFFFFF',Z'FFFFFFFF'/ -C -C MASKS TABLE PUT IN DECIMAL SO IT WILL COMPILE ON ANY 32 BIT -C COMPUTER -C - DATA MASKS / 1, 3, 7, 15, 31, 63, 127, 255, 511, 1023, 2047, - & 4095, 8191, 16383, 32767, 65535, 131071, 262143, 524287, - & 1048575, 2097151, 4194303, 8388607, 16777215, 33554431, - & 67108863, 134217727, 268435455, 536870911, 1073741823, - & 2147483647, -1/ -C -C NBYTE MUST BE LESS THAN OR EQUAL TO NBITSW -C - ICON = NBITSW - NBYTE - IF (ICON.LT.0) RETURN - MASK = MASKS(NBYTE) -C -C INDEX TELLS HOW MANY WORDS INTO IOUT THE NEXT BYTE IS TO BE STORED. -C - INDEX = ISHFT(ISKIP,-5) -C -C II TELLS HOW MANY BITS IN FROM THE LEFT SIDE OF THE WORD TO STORE IT. -C - II = MOD(ISKIP,NBITSW) -C -C ISTEP IS THE DISTANCE IN BITS FROM ONE BYTE POSITION TO THE NEXT. -C - ISTEP = NBYTE + NSKIP -C -C IWORDS TELLS HOW MANY WORDS TO SKIP FROM ONE BYTE TO THE NEXT. -C - IWORDS = ISTEP / NBITSW -C -C IBITS TELLS HOW MANY BITS TO SKIP AFTER SKIPPING IWORDS. -C - IBITS = MOD(ISTEP,NBITSW) -C - DO 10 I = 1,N - J = IAND(MASK,IN(I)) - MOVEL = ICON - II -C -C BYTE IS TO BE STORED IN MIDDLE OF WORD. SHIFT LEFT. -C - IF (MOVEL.GT.0) THEN - MSK = ISHFT(MASK,MOVEL) - IOUT(INDEX+1) = IOR(IAND(NOT(MSK),IOUT(INDEX+1)), - & ISHFT(J,MOVEL)) -C -C THE BYTE IS TO BE SPLIT ACROSS A WORD BREAK. -C - ELSE IF (MOVEL.LT.0) THEN - MSK = MASKS(NBYTE+MOVEL) - IOUT(INDEX+1) = IOR(IAND(NOT(MSK),IOUT(INDEX+1)), - & ISHFT(J,MOVEL)) - ITEMP = IAND(MASKS(NBITSW+MOVEL),IOUT(INDEX+2)) - IOUT(INDEX+2) = IOR(ITEMP,ISHFT(J,NBITSW+MOVEL)) -C -C BYTE IS TO BE STORED RIGHT-ADJUSTED. -C - ELSE - IOUT(INDEX+1) = IOR(IAND(NOT(MASK),IOUT(INDEX+1)),J) - ENDIF -C - II = II + IBITS - INDEX = INDEX + IWORDS - IF (II.GE.NBITSW) THEN - II = II - NBITSW - INDEX = INDEX + 1 - ENDIF -C -10 CONTINUE -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/sbytesc.f b/external/w3nco/v2.0.6/src/sbytesc.f deleted file mode 100644 index dd9a6b5e2..000000000 --- a/external/w3nco/v2.0.6/src/sbytesc.f +++ /dev/null @@ -1,61 +0,0 @@ - SUBROUTINE SBYTESC(OUT,IN,ISKIP,NBYTE,NSKIP,N) -C Store bytes - pack bits: Put arbitrary size values into a -C packed bit string, taking the low order bits from each value -C in the unpacked array. -C IOUT = packed array output -C IN = unpacked array input -C ISKIP = initial number of bits to skip -C NBYTE = number of bits to pack -C NSKIP = additional number of bits to skip on each iteration -C N = number of iterations -C v1.1 -C - character*1 out(*) - integer in(N), bitcnt, ones(8), tbit - save ones - data ones/ 1, 3, 7, 15, 31, 63,127,255/ - -c number bits from zero to ... -c nbit is the last bit of the field to be filled - - nbit = iskip + nbyte - 1 - do i = 1, n - itmp = in(i) - bitcnt = nbyte - index=nbit/8+1 - ibit=mod(nbit,8) - nbit = nbit + nbyte + nskip - -c make byte aligned - if (ibit.ne.7) then - tbit = min(bitcnt,ibit+1) - imask = ishft(ones(tbit),7-ibit) - itmp2 = iand(ishft(itmp,7-ibit),imask) - itmp3 = iand(mova2i(out(index)), 255-imask) - out(index) = char(ior(itmp2,itmp3)) - bitcnt = bitcnt - tbit - itmp = ishft(itmp, -tbit) - index = index - 1 - endif - -c now byte aligned - -c do by bytes - do while (bitcnt.ge.8) - out(index) = char(iand(itmp,255)) - itmp = ishft(itmp,-8) - bitcnt = bitcnt - 8 - index = index - 1 - enddo - -c do last byte - - if (bitcnt.gt.0) then - itmp2 = iand(itmp,ones(bitcnt)) - itmp3 = iand(mova2i(out(index)), 255-ones(bitcnt)) - out(index) = char(ior(itmp2,itmp3)) - endif - enddo - - return - end diff --git a/external/w3nco/v2.0.6/src/skgb.f b/external/w3nco/v2.0.6/src/skgb.f deleted file mode 100644 index fed465475..000000000 --- a/external/w3nco/v2.0.6/src/skgb.f +++ /dev/null @@ -1,78 +0,0 @@ -C----------------------------------------------------------------------- - SUBROUTINE SKGB(LUGB,ISEEK,MSEEK,LSKIP,LGRIB) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: SKGB SEARCH FOR NEXT GRIB MESSAGE -C PRGMMR: IREDELL ORG: W/NMC23 DATE: 93-11-22 -C -C ABSTRACT: THIS SUBPROGRAM SEARCHES A FILE FOR THE NEXT GRIB 1 MESSAGE. -C A GRIB 1 MESSAGE IS IDENTIFIED BY ITS INDICATOR SECTION, I.E. -C AN 8-BYTE SEQUENCE WITH 'GRIB' IN BYTES 1-4 AND 1 IN BYTE 8. -C IF FOUND, THE LENGTH OF THE MESSAGE IS DECODED FROM BYTES 5-7. -C THE SEARCH IS DONE OVER A GIVEN SECTION OF THE FILE. -C THE SEARCH IS TERMINATED IF AN EOF OR I/O ERROR IS ENCOUNTERED. -C -C PROGRAM HISTORY LOG: -C 93-11-22 IREDELL -C 95-10-31 IREDELL ADD CALL TO BAREAD -C 97-03-14 IREDELL CHECK FOR '7777' -C 2001-12-05 GILBERT MODIFIED TO ALSO LOOK FOR GRIB2 MESSAGES -C -C USAGE: CALL SKGB(LUGB,ISEEK,MSEEK,LSKIP,LGRIB) -C INPUT ARGUMENTS: -C LUGB INTEGER LOGICAL UNIT OF INPUT GRIB FILE -C ISEEK INTEGER NUMBER OF BYTES TO SKIP BEFORE SEARCH -C MSEEK INTEGER MAXIMUM NUMBER OF BYTES TO SEARCH -C OUTPUT ARGUMENTS: -C LSKIP INTEGER NUMBER OF BYTES TO SKIP BEFORE MESSAGE -C LGRIB INTEGER NUMBER OF BYTES IN MESSAGE (0 IF NOT FOUND) -C -C SUBPROGRAMS CALLED: -C BAREAD BYTE-ADDRESSABLE READ -C GBYTEC GET INTEGER DATA FROM BYTES -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN -C -C$$$ - PARAMETER(LSEEK=128) - CHARACTER Z(LSEEK) - CHARACTER Z4(4) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - LGRIB=0 - KS=ISEEK - KN=MIN(LSEEK,MSEEK) - KZ=LSEEK -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C LOOP UNTIL GRIB MESSAGE IS FOUND - DOWHILE(LGRIB.EQ.0.AND.KN.GE.8.AND.KZ.EQ.LSEEK) -C READ PARTIAL SECTION - CALL BAREAD(LUGB,KS,KN,KZ,Z) - KM=KZ-8+1 - K=0 -C LOOK FOR 'GRIB...1' IN PARTIAL SECTION - DOWHILE(LGRIB.EQ.0.AND.K.LT.KM) - CALL GBYTEC(Z,I4,(K+0)*8,4*8) - CALL GBYTEC(Z,I1,(K+7)*8,1*8) - IF(I4.EQ.1196575042.AND.(I1.EQ.1.OR.I1.EQ.2)) THEN -C LOOK FOR '7777' AT END OF GRIB MESSAGE - IF (I1.EQ.1) CALL GBYTEC(Z,KG,(K+4)*8,3*8) - IF (I1.EQ.2) CALL GBYTEC(Z,KG,(K+12)*8,4*8) - CALL BAREAD(LUGB,KS+K+KG-4,4,K4,Z4) - IF(K4.EQ.4) THEN - CALL GBYTEC(Z4,I4,0,4*8) - IF(I4.EQ.926365495) THEN -C GRIB MESSAGE FOUND - LSKIP=KS+K - LGRIB=KG - ENDIF - ENDIF - ENDIF - K=K+1 - ENDDO - KS=KS+KM - KN=MIN(LSEEK,ISEEK+MSEEK-KS) - ENDDO -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RETURN - END diff --git a/external/w3nco/v2.0.6/src/summary.c b/external/w3nco/v2.0.6/src/summary.c deleted file mode 100644 index 1ad03e02d..000000000 --- a/external/w3nco/v2.0.6/src/summary.c +++ /dev/null @@ -1,496 +0,0 @@ -/*************************************************************** - -This code will make a system call to return various -useful parameters. When subroutine summary is called, a list -of system resource statistics is printed to stdout. - -Users need to place a call to start() at the beginning of the -section of code to be "measured" and a call to summary() at the end. - -Use as follows: - -call start() - do stuff -call summary() - -Jim Tuccillo August 1999 -***************************************************************/ -#include -#include -#include -#include -#include -#include -#include -#include -#ifdef _AIX -#include -#endif -#ifdef __linux__ -#include -#include -#endif - -/* #include "trace_mpif.h" */ - -static FILE *fp = NULL; -int numtask, mypid; -int procid_0; -int profile, msglen; -int trace_flag; -double tcpu, twall, tbytes, f_bytes; -double tot_wall, final_wall, start_wall; -double cpu_comm, wall_comm; -#ifdef _AIX -extern double rtc (); -#endif -struct time_data { - double s_cpu; - double s_wall; - double f_cpu; - double f_wall; - double c_cpu; - double c_wall; - double c_bytes; - int c_calls; - int c_buckets[32]; - float c_sum[32]; - double b_cpu[32]; - double b_wall[32]; -}; - -struct time_data MPI_Allgather_data; -struct time_data MPI_Allgatherv_data; -struct time_data MPI_Allreduce_data; -struct time_data MPI_Alltoall_data; -struct time_data MPI_Alltoallv_data; -struct time_data MPI_Barrier_data; -struct time_data MPI_Bcast_data; -struct time_data MPI_Gather_data; -struct time_data MPI_Gatherv_data; -struct time_data MPI_Op_create_data; -struct time_data MPI_Op_free_data; -struct time_data MPI_Reduce_scatter_data; -struct time_data MPI_Reduce_data; -struct time_data MPI_Scan_data; -struct time_data MPI_Scatter_data; -struct time_data MPI_Scatterv_data; -struct time_data MPI_Attr_delete_data; -struct time_data MPI_Attr_get_data; -struct time_data MPI_Attr_put_data; -struct time_data MPI_Comm_compare_data; -struct time_data MPI_Comm_create_data; -struct time_data MPI_Comm_dup_data; -struct time_data MPI_Comm_free_data; -struct time_data MPI_Comm_group_data; -struct time_data MPI_Comm_rank_data; -struct time_data MPI_Comm_remote_group_data; -struct time_data MPI_Comm_remote_size_data; -struct time_data MPI_Comm_size_data; -struct time_data MPI_Comm_split_data; -struct time_data MPI_Comm_test_inter_data; -struct time_data MPI_Group_compare_data; -struct time_data MPI_Group_difference_data; -struct time_data MPI_Group_excl_data; -struct time_data MPI_Group_free_data; -struct time_data MPI_Group_incl_data; -struct time_data MPI_Group_intersection_data; -struct time_data MPI_Group_rank_data; -struct time_data MPI_Group_range_excl_data; -struct time_data MPI_Group_range_incl_data; -struct time_data MPI_Group_size_data; -struct time_data MPI_Group_translate_ranks_data; -struct time_data MPI_Group_union_data; -struct time_data MPI_Intercomm_create_data; -struct time_data MPI_Intercomm_merge_data; -struct time_data MPI_Keyval_create_data; -struct time_data MPI_Keyval_free_data; -struct time_data MPI_Abort_data; -struct time_data MPI_Error_class_data; -struct time_data MPI_Errhandler_create_data; -struct time_data MPI_Errhandler_free_data; -struct time_data MPI_Errhandler_get_data; -struct time_data MPI_Error_string_data; -struct time_data MPI_Errhandler_set_data; -struct time_data MPI_Get_processor_name_data; -struct time_data MPI_Initialized_data; -struct time_data MPI_Wtick_data; -struct time_data MPI_Wtime_data; -struct time_data MPI_Address_data; -struct time_data MPI_Bsend_data; -struct time_data MPI_Bsend_init_data; -struct time_data MPI_Buffer_attach_data; -struct time_data MPI_Buffer_detach_data; -struct time_data MPI_Cancel_data; -struct time_data MPI_Request_free_data; -struct time_data MPI_Recv_init_data; -struct time_data MPI_Send_init_data; -struct time_data MPI_Get_elements_data; -struct time_data MPI_Get_count_data; -struct time_data MPI_Ibsend_data; -struct time_data MPI_Iprobe_data; -struct time_data MPI_Irecv_data; -struct time_data MPI_Irsend_data; -struct time_data MPI_Isend_data; -struct time_data MPI_Issend_data; -struct time_data MPI_Pack_data; -struct time_data MPI_Pack_size_data; -struct time_data MPI_Probe_data; -struct time_data MPI_Recv_data; -struct time_data MPI_Rsend_data; -struct time_data MPI_Rsend_init_data; -struct time_data MPI_Send_data; -struct time_data MPI_Sendrecv_data; -struct time_data MPI_Sendrecv_replace_data; -struct time_data MPI_Ssend_data; -struct time_data MPI_Ssend_init_data; -struct time_data MPI_Start_data; -struct time_data MPI_Startall_data; -struct time_data MPI_Test_data; -struct time_data MPI_Testall_data; -struct time_data MPI_Testany_data; -struct time_data MPI_Test_cancelled_data; -struct time_data MPI_Testsome_data; -struct time_data MPI_Type_commit_data; -struct time_data MPI_Type_contiguous_data; -struct time_data MPI_Type_extent_data; -struct time_data MPI_Type_free_data; -struct time_data MPI_Type_hindexed_data; -struct time_data MPI_Type_hvector_data; -struct time_data MPI_Type_indexed_data; -struct time_data MPI_Type_lb_data; -struct time_data MPI_Type_size_data; -struct time_data MPI_Type_struct_data; -struct time_data MPI_Type_ub_data; -struct time_data MPI_Type_vector_data; -struct time_data MPI_Unpack_data; -struct time_data MPI_Wait_data; -struct time_data MPI_Waitall_data; -struct time_data MPI_Waitany_data; -struct time_data MPI_Waitsome_data; -struct time_data MPI_Cart_coords_data; -struct time_data MPI_Cart_create_data; -struct time_data MPI_Cart_get_data; -struct time_data MPI_Cart_map_data; -struct time_data MPI_Cart_rank_data; -struct time_data MPI_Cart_shift_data; -struct time_data MPI_Cart_sub_data; -struct time_data MPI_Cartdim_get_data; -struct time_data MPI_Dims_create_data; -struct time_data MPI_Graph_create_data; -struct time_data MPI_Graph_get_data; -struct time_data MPI_Graph_map_data; -struct time_data MPI_Graph_neighbors_data; -struct time_data MPI_Graph_neighbors_count_data; -struct time_data MPI_Graphdims_get_data; -struct time_data MPI_Topo_test_data; - - -int bucket (lng) - int lng; -{ - int i, j; - if (lng <= 0) {return(0);} - for (i=1, j=--lng; j>0; ++i) { - j = j>>1; - } - return (i); -} - - - -void elapse (timer) - double *timer; - -{ - -/* - - typedef struct { unsigned long tv_sec; - long tv_nsec; } timestruc; - - timestruc TimePointer; - int ret; - - ret = gettimer (TIMEOFDAY, &TimePointer); - if (ret != 0) { - printf ("getttimer FAILED!!!\n"); - printf ("ret = %d\n", ret); - return; - } - - - *timer = ((double) TimePointer.tv_sec) + (((double) TimePointer.tv_nsec) * ((double) 0.000000001)); - return; - -*/ -#ifdef _AIX - *timer = rtc(); -#endif -#ifdef __linux__ - struct timeval st; - if (gettimeofday (&st, NULL) == -1) { - fprintf (stderr, - "elapse: gettimeofday: %s.\n", - strerror (errno)); - *timer = 0.; - } - *timer = ((double) st.tv_sec) + 1.e-6 * ((double) st.tv_usec); -#endif - -} - - -void cputim (usr, sys) - double *usr; - double *sys; - -{ - - double real; - typedef struct { int tms_utime; - int tms_stime; - int tms_cutime; - int tms_cstime; } tms; - - tms Time_buffer; - int ret; - - ret = times (&Time_buffer); - - real = ((double) ret) * 0.01; - - *usr = ((double) Time_buffer.tms_utime) * 0.01; - *sys = ((double) Time_buffer.tms_stime) * 0.01; - return; - -} - - -void start_timer (time) - struct time_data *time; - -{ - double user, sys; - double wall; - - cputim (&user, &sys); - elapse (&wall); - time->s_cpu = user + sys; - time->s_wall = wall; - - return; -} - -void end_timer (time) - struct time_data *time; - -{ - double user, sys; - double wall; - - cputim (&user, &sys); - elapse (&wall); - time->f_cpu = user + sys; - time->f_wall = wall; - time->c_cpu += time->f_cpu - time->s_cpu; - time->c_wall += time->f_wall - time->s_wall; - - return; -} - - - - -void resource () - -{ - - double usr, sys; - long data[14]; -#ifdef _AIX - typedef struct { - int tv_sec; /* seconds */ - int tv_usec; /* microseconds */ - } timeval; -#endif - double user, system; - int ret; - - struct rusage RU; - ret = getrusage (0, &RU); - - if (ret != 0) { - printf ("getrusage FAILED!!!\n"); - printf ("ret = %d\n", ret); - return; - } - - - user = ((double) RU.ru_utime.tv_sec) + (((double) RU.ru_utime.tv_usec) * ((double) 0.000001)); - system = ((double) RU.ru_stime.tv_sec) + (((double) RU.ru_stime.tv_usec) * ((double) 0.000001)); - - - printf("*****************RESOURCE STATISTICS*******************************\n"); - printf("The total amount of wall time = %f\n", tot_wall); - printf("The total amount of time in user mode = %f\n", user); - printf("The total amount of time in sys mode = %f\n", system); -#ifdef _AIX - printf("The maximum resident set size (KB) = %d\n", RU.ru_maxrss); - printf("Average shared memory use in text segment (KB*sec) = %d\n", RU.ru_ixrss); - printf("Average unshared memory use in data segment (KB*sec) = %d\n", RU.ru_idrss); - printf("Average unshared memory use in stack segment(KB*sec) = %d\n", RU.ru_isrss); - printf("Number of page faults without I/O activity = %d\n", RU.ru_minflt); - printf("Number of page faults with I/O activity = %d\n", RU.ru_majflt); - printf("Number of times process was swapped out = %d\n", RU.ru_nswap); - printf("Number of times filesystem performed INPUT = %d\n", RU.ru_inblock); - printf("Number of times filesystem performed OUTPUT = %d\n", RU.ru_oublock); - printf("Number of IPC messages sent = %d\n", RU.ru_msgsnd); - printf("Number of IPC messages received = %d\n", RU.ru_msgrcv); - printf("Number of Signals delivered = %d\n", RU.ru_nsignals); - printf("Number of Voluntary Context Switches = %d\n", RU.ru_nvcsw); - printf("Number of InVoluntary Context Switches = %d\n", RU.ru_nivcsw); -#endif -#ifdef __linux__ - printf ("The maximum resident set size (KB) = %ld\n", RU.ru_maxrss); - printf ("Number of page faults without I/O activity = %ld\n", RU.ru_minflt); - printf ("Number of page faults with I/O activity = %ld\n", RU.ru_majflt); - printf ("Number of times filesystem performed INPUT = %ld\n", RU.ru_inblock); - printf ("Number of times filesystem performed OUTPUT = %ld\n", RU.ru_oublock); - printf ("Number of Voluntary Context Switches = %ld\n", RU.ru_nvcsw); - printf ("Number of InVoluntary Context Switches = %ld\n", RU.ru_nivcsw); -#endif - printf("*****************END OF RESOURCE STATISTICS*************************\n\n"); - - - usr = user; - sys = system; - data[0] = RU.ru_maxrss; - data[1] = RU.ru_ixrss; - data[2] = RU.ru_idrss; - data[3] = RU.ru_isrss; - data[4] = RU.ru_minflt; - data[5] = RU.ru_majflt; - data[6] = RU.ru_nswap; - data[7] = RU.ru_inblock; - data[8] = RU.ru_oublock; - data[9] = RU.ru_msgsnd; - data[10] = RU.ru_msgrcv; - data[11] = RU.ru_nsignals; - data[12] = RU.ru_nvcsw; - data[13] = RU.ru_nivcsw; - - return; - -} - - - - - -void print_timing (string, time) - char *string; - struct time_data *time; - -{ - - - if (time->c_calls > 0) { - fprintf (fp, "Information for %s: AVG. Length = %13.2f, CALLS = %d, WALL = %13.3f, CPU = %13.3f \n", - string, (double) (time->c_bytes) / (double) time->c_calls, time->c_calls, - time->c_wall, time->c_cpu); - } - - if (time->c_wall > 0.001 ) { - fprintf (fp, " %s: Total BYTES = %g, BW = %8.3f MBYTES/WALL SEC., BW = %8.3f MBYTES/CPU SEC.\n", - string, time->c_bytes, - ((double) time->c_bytes * 0.000001)/time->c_wall, - ((double) time->c_bytes * 0.000001)/time->c_cpu); - } - - twall += time->c_wall; - tcpu += time->c_cpu; - tbytes += time->c_bytes * 0.000001; - - /* Print the distribution of the message lengths */ - if (time->c_calls > 0) { - int i, j1, j2; - - j1 = 0; j2 = 0; - fprintf (fp, " AVG. Length # of Calls MB/WALL Sec. MB/CPU Sec. WALL Secs. CPU Secs. \n"); - if (time->c_buckets[0] >0) { - fprintf (fp, " %13.2f %13d %13.3f %13.3f %13.4f %13.4f \n", - time->c_sum[0]/(float)time->c_buckets[0], time->c_buckets[0], - ((double) time->c_sum[0] * 0.000001)/time->b_wall[0], - ((double) time->c_sum[0] * 0.000001)/time->b_cpu[0], - time->b_wall[0], time->b_cpu[0]); - } - time->c_buckets[3] = time->c_buckets[1] + time->c_buckets[2] + time->c_buckets[3]; - j1 = 1; j2 = 4; - for (i =3; i < 31; ++i) { - if (time->c_buckets[i] > 0) { - fprintf (fp, " %13.2f %13d %13.3f %13.3f %13.4f %13.4f \n", - time->c_sum[i]/(float)time->c_buckets[i], time->c_buckets[i], - ((double) time->c_sum[i] * 0.000001)/time->b_wall[i], - ((double) time->c_sum[i] * 0.000001)/time->b_cpu[i], - time->b_wall[i], time->b_cpu[i]); - } - j1 = j2 +1; - j2 = j2 + j2; - } - - fprintf (fp, "\n"); - - } - -} - -#ifdef _AIX -void summary( returnVal ) -int * returnVal; -#endif -#if defined(__linux__) || (__APPLE__) -void summary_ (int *returnVal) -#endif -{ - - double temp, temp1; - char trace_file[255], processor[8]; - -/* - MPI_Finalize - prototyping replacement for MPI_Finalize -*/ - - elapse(&final_wall); - tot_wall = final_wall - start_wall; - - - resource(); - - if (fp) fclose (fp); - - return; -} - -#ifdef _AIX -void start() -#endif -#if defined(__linux__) || (__APPLE__) -void start_ () -#endif -{ - int stateid; - int Argc; - char **Argv; - - char *answer; - - - trace_flag=1; - - profile = 0; - elapse (&start_wall); - - return; -} - diff --git a/external/w3nco/v2.0.6/src/w3ai00.f b/external/w3nco/v2.0.6/src/w3ai00.f deleted file mode 100644 index 5f769434b..000000000 --- a/external/w3nco/v2.0.6/src/w3ai00.f +++ /dev/null @@ -1,505 +0,0 @@ - SUBROUTINE W3AI00(REAL8,PACK,LABEL) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: W3AI00 REAL ARRAY TO 16 BIT PACKED FORMAT -C AUTHOR: JONES,R.E. ORG: W342 DATE: 85-07-31 -C -C ABSTRACT: CONVERTS IEEE FLOATING POINT NUMBERS TO 16 BIT -C PACKED OFFICE NOTE 84 FORMAT. THE FLOATING POINT NUMBER ARE -C CONVERTED TO 16 BIT SIGNED SCALED INTEGERS. -C -C PROGRAM HISTORY LOG: -C 89-10-20 R.E.JONES CONVERT CYBER 205 VERSION OF W3AI00 TO CRAY -C 90-03-18 R.E.JONES CHANGE TO USE CRAY INTEGER*2 PACKER -C 90-10-11 R.E.JONES SPECIAL VERSION TO PACK GRIDS LARGER THAN -C 32743 WORDS. WILL DO OLD AND NEW VERSION. -C 91-02-16 R.E.JONES CHANGES SO EQUIVALENCE OF PACK AND REAL8 -C ARRAYS WILL WORK. -C 93-06-10 R.E.JONES CHANGES FOR ARRAY SIZE (512,512) 262144 WORDS. -C 98-03-10 B. VUONG REMOVE THE CDIR$ INTEGER=64 DIRECTIVE -C 98-11-18 Gilbert Changed to pack IEEE values for the IBM SP -C -C USAGE: CALL W3AI00 (REAL8, PACK, LABEL) -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C REAL8 ARG LIST ARRAY OF CRAY FLOATING POINT NUMBERS -C LABEL ARG LIST SIX 8-BYTE INTEGER WORDS. -C MUST HAVE FIRST 8 OF 12 32 BIT -C WORD OFFICE NOTE 84 LABEL. WORD 6 MUST HAVE -C IN BITS 31-00 THE NUMBER OF REAL WORDS IN ARRAY -C REAL8 IF J IS GREATER THAN 32743. J IN BITS -C 15-0 OF THE 4TH ID WORD IS SET ZERO. -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C PACK ARG LIST PACKED OUTPUT ARRAY OF INTEGER WORDS OF -C SIZE 6 + (J+3)/4 , J = NO. POINTS IN LABEL -C (FROM WORD 4 BITS 15-00). -C LABEL WILL BE COPIED TO PACK WORDS 1-4. PACK -C WILL CONTAIN THE FOLLOWING IN WORDS 5-6 -C WORD 5 BITS 63-48 NUMBER OF BYTES IN WHOLE -C RECORD. WILL NOT BE -C CORRECT IF J > 32743. -C WORD 5 BITS 47-32 EXCLUSIVE-OR CHECKSUM BY 16 -C BIT WORDS OF WHOLE ARRAY PACK -C EXCLUDING CHECKSUM ITSELF. -C WORD 5 BITS 31-00 CENTER VALUE A = MEAN OF -C MAX AND MIN VALUES. -C CONVERTED TO IBM 32 -C FLOATING POINT NUMBER. -C WORD 6 BITS 63-48 ZERO. -C WORD 6 BITS 47-32 16 BIT SHIFT VALUE N. THE -C LEAST INTEGER SUCH THAT -C ABS(X-A)/2**N LT 1 FOR -C ALL X IN REAL8. LIMITED -C TO +-127. -C WORD 6 BITS 31-00 NUMBER OF WORDS IN REAL8 -C IF > 32743, RIGHT ADJUSTED -C IF <= 32743 SET ZERO. -C -C SUBPROGRAMS CALLED: -C NAMES LIBRARY -C ------------------------------------------------------- -------- -C IAND IOR BTEST SYSTEM -C -C REMARKS: PACK AND LABEL MAY BE EQUIVALENCED. N, THE NUMBER OF -C POINTS IN A GRID IS NOW IN 32 BIT ID WORD 12. -C -C ATTRIBUTES: -C LANGUAGE: IBM XL FORTRAN. -C MACHINE: IBM SP -C -C$$$ -C - REAL REAL8(*) - REAL XX(262144) -C - INTEGER(8) KK(262144) - INTEGER(8) LABEL(6) - INTEGER(8) PACK(*) - INTEGER(8) TPACK(6) - INTEGER(8) MASK16,MASK32,MASKN,IBYTES,IXOR - INTEGER(8) IB,N - REAL(8) B - REAL(4) X,A - real(4) rtemp(2) - integer(8) irtemp - equivalence (irtemp,rtemp(1)) -C - SAVE -C - EQUIVALENCE (B,IB) -C - DATA MASK16/X'000000000000FFFF'/ - DATA MASK32/X'00000000FFFFFFFF'/ - DATA MASKN /X'0000FFFF00000000'/ -C -C TRANSFER LABEL DATA TO WORDS 1-4. GET WORD COUNT, COMPUTE BYTES. -C - DO 10 I = 1,4 - TPACK(I) = LABEL(I) - 10 CONTINUE -C - TPACK(5) = 0 - TPACK(6) = 0 -C -C GET J, THE NUMBER OF WORDS IN A GRID, IF ZERO GET THE -C GET J FROM OFFICE NOTE 84 ID WORD 12. -C - J = IAND(MASK16,TPACK(4)) - IF (J.EQ.0) THEN - TPACK(6) = LABEL(6) - J = IAND(MASK32,TPACK(6)) - IF (J.EQ.0) THEN - PRINT *,' W3AI00: ERROR, NO. OF WORDS IN GRID = 0' - RETURN - ENDIF - IF (J.GT.262144) THEN - PRINT *,' W3AI00: ERROR, NO. OF WORDS IN GRID = ',J - PRINT *,' THERE IS A LIMIT OF 262144 WORDS.' - RETURN - ENDIF - ENDIF - M = J + 24 -C -C COMPUTE THE NUMBER OF 64 BIT INTEGER CRAY WORDS NEEDED FOR -C PACKED DATA. -C - IF (MOD(M,4).NE.0) THEN - IWORD = (M + 3) / 4 - ELSE - IWORD = M / 4 - ENDIF -C - IBYTES = M + M -C -C STORE NUMBER OF BYTES IN RECORD IN BITS 63-48 OF WORD 5. -C BITS ARE NUMBERED LEFT TO RIGHT 63 T0 00 -C - TPACK(5) = ISHFT(IBYTES,48_8) -C -C FIND MAX, MIN OF DATA, COMPUTE A AND N. -C - RMAX = REAL8(1) - RMIN = RMAX - DO 20 I = 2,J - RMAX = AMAX1(RMAX,REAL8(I)) - RMIN = AMIN1(RMIN,REAL8(I)) - 20 CONTINUE -C - A = 0.5 * (RMAX + RMIN) - X = RMAX - A - IF (RMAX.NE.RMIN) THEN -C CALL USDCTI(X,B,1,1,ISTAT) - CALL Q9E3I6(X,B,1,ISTAT) - IF (ISTAT.NE.0) PRINT *,' W3AI00-USDCTI OVERFLOW ERROR 1' - N = IAND(ISHFT(IB,-56_8),127_8) - N = 4 * (N - 64) - IF (BTEST(IB,55_8)) GO TO 30 - N = N - 1 - IF (BTEST(IB,54_8)) GO TO 30 - N = N - 1 - IF (BTEST(IB,53_8)) GO TO 30 - N = N - 1 - 30 CONTINUE - N = MAX0(-127_8,MIN0(127_8,N)) - ELSE -C -C FIELD IS ZERO OR A CONSTANT -C - N = 0 - ENDIF -C -C CONVERT AVERAGE VALUE FROM IEEE F.P. TO IBM370 32 BIT -C STORE IBM370 32 BIT F.P. AVG. VALUE IN BITS 31 - 00 OF WORD 5. -C -C CALL USSCTI(A,TPACK(5),5,1,ISTAT) - CALL Q9EI32(A,rtemp(2),1,ISTAT) - IF (ISTAT.NE.0) PRINT *,' W3AI00-USDCTI OVERFLOW ERROR 2' - TPACK(5)=IOR(TPACK(5),irtemp) -C -C STORE SCALING VALUE N IN BITS 47 - 32 OF WORD 6. -C - TPACK(6) = IOR(IAND(MASKN,ISHFT(N,32_8)),TPACK(6)) -C -C NOW PACK UP THE DATA, AND SCALE IT TO FIT AN INTEGER*2 WORD -C - TWON = 2.0 ** (15 - N) - DO 40 I = 1,J - XX(I) = (REAL8(I) - A) * TWON - KK(I) = XX(I) + SIGN(0.5,XX(I)) - IF (KK(I).GE.(-32767)) THEN - KK(I) = MIN0(32767_8,KK(I)) - ELSE - KK(I) = -32767 - ENDIF - KK(I) = IAND(KK(I),MASK16) - 40 CONTINUE -C -C SHIFT THE INTEGER*2 DATA TO FIT 4 IN A 64 BIT WORD -C - LIM = (J / 4 ) * 4 - IREM = J - LIM - DO 50 I = 1,LIM,4 - KK(I) = ISHFT(KK(I), 48_8) - KK(I+1) = ISHFT(KK(I+1),32_8) - KK(I+2) = ISHFT(KK(I+2),16_8) - 50 CONTINUE -C -C SHIFT THE REMAINING 1, 2, OR 3 INTEGER*2 WORDS -C - IF (IREM.EQ.1) THEN - KK(LIM+1) = ISHFT(KK(LIM+1),48_8) - ENDIF -C - IF (IREM.EQ.2) THEN - KK(LIM+1) = ISHFT(KK(LIM+1),48_8) - KK(LIM+2) = ISHFT(KK(LIM+2),32_8) - ENDIF -C - IF (IREM.EQ.3) THEN - KK(LIM+1) = ISHFT(KK(LIM+1),48_8) - KK(LIM+2) = ISHFT(KK(LIM+2),32_8) - KK(LIM+3) = ISHFT(KK(LIM+3),16_8) - ENDIF -C -C PACK THE DATA BY USE OF IOR FOUR TO A WORD -C - II = 7 - DO 60 I = 1,LIM,4 - PACK(II) = IOR(IOR(IOR(KK(I),KK(I+1)),KK(I+2)),KK(I+3)) - II = II + 1 - 60 CONTINUE -C -C PACK THE LAST 1, 2, OR 3 INTEGER*2 WORDS -C - IF (IREM.EQ.1) THEN - PACK(IWORD) = KK(LIM+1) - ENDIF -C - IF (IREM.EQ.2) THEN - PACK(IWORD) = IOR(KK(I),KK(I+1)) - ENDIF -C - IF (IREM.EQ.3) THEN - PACK(IWORD) = IOR(IOR(KK(I),KK(I+1)),KK(I+2)) - ENDIF -C -C MOVE LABEL FROM TEMPORARY ARRAY TO PACK -C - DO 70 I = 1,6 - PACK(I) = TPACK(I) - 70 CONTINUE -C -C COMPUTE CHECKSUM AND STORE -C - IXOR = 0 -C -C COMPUTES A 64 BIT CHECKSUM 1ST -C - DO 80 I = 1,IWORD - IXOR = IEOR(IXOR,PACK(I)) - 80 CONTINUE -C -C COMPUTES A 32 BIT CHECKSUM 2ND -C - IXOR = IEOR(ISHFT(IXOR,-32_8),IAND(IXOR,MASK32)) -C -C COMPUTES A 16 BIT CHECKSUM 3RD -C - IXOR = IEOR(ISHFT(IXOR,-16_8),IAND(IXOR,MASK16)) -C -C STORE 16 BIT CHECK SUM OF RECORD IN BITS 47-32 OF WORD 5. -C - PACK(5) = IOR(ISHFT(IXOR,32_8),PACK(5)) -C - RETURN - END - - SUBROUTINE Q9EI32(A,B,N,ISTAT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: Q9EI32 IEEE 32 BIT F.P. TO IBM370 F.P. -C PRGMMR: R.E.JONES ORG: W/NMC42 DATE: 90-06-04 -C -C ABSTRACT: CONVERT IEEE 32 BIT TASK 754 FLOATING POINT NUMBERS -C TO IBM370 32 BIT FLOATING POINT NUMBERS. -C -C PROGRAM HISTORY LOG: -C 90-06-04 R.E.JONES CONVERT TO SUN FORTRAN 1.3 -C 90-07-14 R.E.JONES CHANGE ISHFT TO LSHIFT OR LRSHFT -C 91-03-28 R.E.JONES CHANGE TO SiliconGraphics 3.3 FORTRAN 77 -C 92-07-20 R.E.JONES CHANGE TO IBM AIX XL FORTRAN -C 95-11-15 R.E.JONES ADD SAVE STATEMENT -C 98-11-18 Gilbert Specified 4-byte Integer values -C -C USAGE: CALL Q9EI32(A, B, N, ISTAT) -C INPUT ARGUMENT LIST: -C A - REAL*4 ARRAY OF IEEE 32 BIT FLOATING POINT NUMBERS -C N - NUMBER OF WORDS TO CONVERT TO IBM370 32 BIT F.P. -C -C OUTPUT ARGUMENT LIST: -C B - REAL*4 ARRAY OF IBM370 32 BIT FLOATING POINT NUMBERS -C ISTAT - 0 , ALL NUMBERS CONVERTED -C -1 , N IS LESS THAN ONE -C +K , K INFINITY OR NAN NUMBERS WERE FOUND -C -C REMARKS: SEE IEEE TASK 754 STANDARD FLOATING POINT ARITHMETIC FOR -C MORE INFORMATION ABOUT IEEE F.P. -C -C ATTRIBUTES: -C LANGUAGE: IBM AIX XL FORTRAN Compiler/6000 -C MACHINE: IBM RS6000 model 530 -C -C$$$ -C - INTEGER(4) A(*) - INTEGER(4) B(*) - INTEGER(4) SIGN,MASKFR,IBIT8,MASKSN,ITEMP,IBMEXP,IBX7 - INTEGER(4) ISIGN -C - SAVE -C - DATA MASKFR/Z'00FFFFFF'/ - DATA IBIT8 /Z'00800000'/ - DATA MASKSN/Z'7FFFFFFF'/ - DATA SIGN /Z'80000000'/ -C - IF (N.LT.1) THEN - ISTAT = -1 - RETURN - ENDIF -C - ISTAT = 0 -C - DO 30 I = 1,N -C -C SIGN BIT OFF -C - ISIGN = 0 - ITEMP = A(I) -C -C TEST SIGN BIT -C - IF (ITEMP.EQ.0) GO TO 20 -C - IF (ITEMP.LT.0) THEN -C -C SIGN BIT ON -C - ISIGN = SIGN -C -C TURN SIGN BIT OFF -C - ITEMP = IAND(ITEMP,MASKSN) -C - END IF -C - IBMEXP = ISHFT(ITEMP,-23_4) -C -C TEST FOR INDIFINITE OR NAN NUMBER -C - IF (IBMEXP.EQ.255) GO TO 10 -C -C TEST FOR ZERO EXPONENT AND FRACTION (UNDERFLOW) -C - IF (IBMEXP.EQ.0) GO TO 20 - IBMEXP = IBMEXP + 133 - IBX7 = IAND(3_4,IBMEXP) - IBMEXP = IEOR(IBMEXP,IBX7) - IBX7 = IEOR(3_4,IBX7) - ITEMP = IOR(ITEMP,IBIT8) - ITEMP = IOR(ISHFT(IBMEXP,22_4),ISHFT(IAND(ITEMP,MASKFR), - & -IBX7)) - B(I) = IOR(ITEMP,ISIGN) - GO TO 30 -C - 10 CONTINUE -C -C ADD 1 TO ISTAT FOR INDEFINITE OR NAN NUMBER -C - ISTAT = ISTAT + 1 -C - 20 CONTINUE - B(I) = 0 -C - 30 CONTINUE -C - RETURN - END - - SUBROUTINE Q9E3I6(A,B,N,ISTAT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: Q9E3I6 IEEE 32 BIT F.P. TO IBM370 64 BIT F.P. -C PRGMMR: R.E.JONES ORG: W/NMC42 DATE: 92-08-02 -C -C ABSTRACT: CONVERT IEEE 32 BIT TASK 754 FLOATING POINT NUMBERS -C TO IBM370 64 BIT FLOATING POINT NUMBERS. -C -C PROGRAM HISTORY LOG: -C 92-08-02 R.E.JONES -C 95-11-15 R.E.JONES ADD SAVE STATEMENT -C -C USAGE: CALL Q9E3I6(A, B, N, ISTAT) -C INPUT ARGUMENT LIST: -C A - REAL*4 ARRAY OF IEEE 32 BIT FLOATING POINT NUMBERS -C N - NUMBER OF WORDS TO CONVERT TO IBM370 64 BIT F.P. -C -C OUTPUT ARGUMENT LIST: -C B - REAL*8 ARRAY OF IBM370 64 BIT FLOATING POINT NUMBERS -C ISTAT - 0 , ALL NUMBERS CONVERTED -C -1 , N IS LESS THAN ONE -C +K , K INFINITY OR NAN NUMBERS WERE FOUND -C -C REMARKS: SEE IEEE TASK 754 STANDARD FLOATING POINT ARITHMETIC FOR -C MORE INFORMATION ABOUT IEEE F.P. -C -C ATTRIBUTES: -C LANGUAGE: IBM AIX XL FORTRAN -C MACHINE: IBM RS/6000 model 530 -C -C$$$ -C - INTEGER(4) A(N) - INTEGER(4) B(2,N) - INTEGER(4) SIGN,MASKFR,IBIT8,MASKSN,ITEMP,IEEEXP - INTEGER(4) IBMEXP,IBX7,JTEMP,ISIGN -C - SAVE -C - DATA MASKFR/Z'00FFFFFF'/ - DATA IBIT8 /Z'00800000'/ - DATA MASKSN/Z'7FFFFFFF'/ - DATA SIGN /Z'80000000'/ -C - IF (N.LT.1) THEN - ISTAT = -1 - RETURN - ENDIF -C - ISTAT = 0 -C - DO 30 I = 1,N - ISIGN = 0 - ITEMP = A(I) -C -C TEST SIGN BIT -C - IF (ITEMP.EQ.0) GO TO 20 -C -C TEST FOR NEGATIVE NUMBERS -C - IF (ITEMP.LT.0) THEN -C -C SIGN BIT ON -C - ISIGN = SIGN -C -C TURN SIGN BIT OFF -C - ITEMP = IAND(ITEMP,MASKSN) -C - END IF -C -C GET IEEE EXPONENT -C - IEEEXP = ISHFT(ITEMP,-23_4) -C -C TEST FOR INDIFINITE OR NAN NUMBER -C - IF (IEEEXP.EQ.255) GO TO 10 -C -C TEST FOR ZERO EXPONENT AND FRACTION (UNDERFLOW) -C CONVERT IEEE EXPONENT (BASE 2) TO IBM EXPONENT -C (BASE 16) -C - IF (IEEEXP.EQ.0) GO TO 20 - IBMEXP = IEEEXP + 133 - IBX7 = IAND(3_4,IBMEXP) - IBMEXP = IEOR(IBMEXP,IBX7) - IBX7 = IEOR(3_4,IBX7) - ITEMP = IOR(ITEMP,IBIT8) - JTEMP = IOR(ISHFT(IBMEXP,22_4),ISHFT(IAND(ITEMP,MASKFR), - & -IBX7)) - B(1,I) = IOR(JTEMP,ISIGN) - B(2,I) = 0 - IF (IBX7.GT.0) B(2,I) = ISHFT(ITEMP,32_4-IBX7) - GO TO 30 -C - 10 CONTINUE -C ADD 1 TO ISTAT FOR INDEFINITE OR NAN NUMBER -C - ISTAT = ISTAT + 1 -C - 20 CONTINUE - B(1,I) = 0 - B(2,I) = 0 -C - 30 CONTINUE -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3ai01.f b/external/w3nco/v2.0.6/src/w3ai01.f deleted file mode 100644 index 854239425..000000000 --- a/external/w3nco/v2.0.6/src/w3ai01.f +++ /dev/null @@ -1,120 +0,0 @@ - SUBROUTINE W3AI01(PACK,REAL8,LABEL) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: W3AI01 UNPACK RECORD INTO IEEE F.P. -C AUTHOR: JONES,R.E. ORG: W342 DATE: 89-10-17 -C -C ABSTRACT: UNPACKS A RECORD IN OFFICE NOTE 84 FORMAT AND CONVERT THE -C PACKED DATA TO IEEE REAL FLOATING POINT NUMBERS. THE -C OFFICE NOTE 84 DATA IS BIT FOR BIT THE SAME ON THE NAS-9050 AND -C THE CRAY. -C -C PROGRAM HISTORY LOG: -C 89-10-20 R.E.JONES -C 90-02-02 R.E.JONES CHANGE TO CRAY FUNCTION FOR INTEGER*2, F.P. -C 90-10-11 R.E.JONES SPECIAL VERSION OF W3AI01 TO UNPACK RECORDS -C PACKED BY BIG VERSION OF W3AI00. WILL DO -C OLD AND NEW VERSION. -C 91-03-19 R.E.JONES MAKE SPECIAL VERSION OF W3AI01 TO UNPACK -C BIG RECORDS THE OPERATIONAL VERSION. -C 93-06-10 R.E.JONES INCREACE ARRAY SIZE TO 262144 WORDS. -C 98-03-10 B. VUONG REMOVE THE CDIR$ INTEGER=64 DIRECTIVE -C 98-11-17 Gilbert Changed to unpack into IEEE reals for the IBM SP -C -C USAGE: CALL W3AI01 (PACK, REAL8, LABEL) -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C PACK ARG LIST INTEGER ARRAY WITH DATA IN OFFICE NOTE 84 -C FORMAT TO BE UNPACKED. -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C REAL8 ARG LIST REAL ARRAY OF N WORDS. WHERE N IS GIVEN IN -C WORD 6 OF PACK. WORD 6 OF PACK MUST -C CONTAIN CENTER AND SCALING VALUES. -C LABEL ARG LIST SIX WORD INTEGER LABEL COPIED FROM PACK, 12 -C OFFICE NOTE 84 32 BIT ID'S THAT ARE STORED INTO -C six 64-bit words. -C -C SUBPROGRAMS CALLED: -C NAMES LIBRARY -C ------------------------------------------------------- -------- -C Q9IE32 W3LIB -C -C REMARKS: LABEL AND PACK MAY BE EQUIVALENCED. -C -C ATTRIBUTES: -C LANGUAGE: IBM XL FORTRAN -C MACHINE: IBM SP -C -C$$$ -C - REAL REAL8(*) -C - INTEGER(2) ITEMP(262144) - INTEGER(8) LABEL(6) - INTEGER(8) PACK(*) - INTEGER(8) MASK16 - INTEGER(8) MASK32 - integer(2) i2(4) - real(4) rtemp(2) - integer(8) ktemp,jtemp(65536) - equivalence (ktemp,rtemp(1),i2(1)) - equivalence (itemp(1),jtemp(1)) -C - SAVE -C - DATA MASK16/X'000000000000FFFF'/ - DATA MASK32/X'00000000FFFFFFFF'/ -C -C MOVE OFFICE NOTE 84 12 32 BIT ID'S INTO LABEL -C - DO 10 I = 1,6 - LABEL(I) = PACK(I) - 10 CONTINUE -C -C GET WORD COUNT, AVERAGE VALUE, SCALING FACTOR, J, A , N. -C - J = IAND(LABEL(4),MASK16) - IF (J.EQ.0) THEN - J = IAND(LABEL(6),MASK32) - IF (J.EQ.0) THEN - PRINT *,' W3AI01 ERROR, NUMBER OF WORDS IN GRID IS 0' - RETURN - ENDIF - IF (J.GT.262144) THEN - PRINT *,' W3AI01 ERROR, NUMBER OF WORDS IN GRID IS ',J - PRINT *,' THERE IS A LIMIT OF 262144' - RETURN - ENDIF - ENDIF -C -C CONVERT IBM 32 BIT MEAN VALUE TO IEEE F.P. NUMBER -C -C CALL USSCTC(LABEL(5),5,A,1) - ktemp=LABEL(5) - call q9ie32(rtemp(2),rtemp(1),1,istat) - A=rtemp(1) -C -C GET SCALING VALUE N, CAN BE NEGATIVE (INTEGER*2 TWO'S COMPL.) -C -C CALL USICTC(LABEL(6),3,N,1,2) - ktemp=LABEL(6) - n=i2(2) -C - TWON = 2.0 ** (N - 15) -C -C UNPACK, CONVERT TO REAL 64 BIT FLOATING POINT DATA -C -C CALL USICTC(PACK(7),1,ITEMP,J,2) - jtemp(1:65536)=pack(7:65542) -C - DO 20 I = 1,J - REAL8(I) = FLOAT(ITEMP(I)) * TWON + A - 20 CONTINUE -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3ai08.f b/external/w3nco/v2.0.6/src/w3ai08.f deleted file mode 100644 index f7b4de326..000000000 --- a/external/w3nco/v2.0.6/src/w3ai08.f +++ /dev/null @@ -1,2848 +0,0 @@ - SUBROUTINE W3AI08(MSGA,KPDS,KGDS,KBMS,DATA,KPTR,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3AI08 UNPK GRIB FIELD TO GRIB GRID -C PRGMMR: BOSTELMAN ORG: NMC421 DATE:90-07-31 -C -C ABSTRACT: UNPACK A GRIB FIELD TO THE EXACT GRID SPECIFIED IN THE -C MESSAGE, ISOLATE THE BIT MAP AND MAKE THE VALUES OF THE PRODUCT -C DESCRIPTION SEC (PDS) AND THE GRID DESCRIPTION SEC (GDS) -C AVAILABLE IN RETURN ARRAYS. -C -C PROGRAM HISTORY LOG: -C 88-01-20 CAVANAUGH -C 90-05-11 CAVANAUGH TO ASSURE THAT ALL U.S. GRIDS IN THE -C GRIB DECODER COMPLY WITH SIZE CHANGES -C IN THE DECEMBER 1989 REVISIONS. -C 90-05-24 CAVANAUGH CORRECTS SEARCHING AN IMPROPER LOCATION -C FOR GRIB VERSION NUMBER IN GRIB MESSAGES. -C 90-07-15 BOSTELMAN MODIIFED SUB. AI084 SO THAT IT WILL TEST -C THE GRIB BDS BYTE SIZE TO DETERMINE WHAT -C ECMWF GRID ARRAY SIZE IS TO BE SPECIFIED. -C 90-09-14 R.E.JONES CHANGE'S FOR ANSI FORTRAN, AND PDS VERSION 1 -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C 90-12-05 R.E.JONES CHANGE'S FOR GRIB NOV. 21,1990 -C 02-10-15 VUONG REPLACED FUNCTION ICHAR WITH MOVA2I -C -C USAGE: CALL W3AI08(MSGA,KPDS,KGDS,KBMS,DATA,KPTR,KRET) -C INPUT ARGUMENT LIST: -C MSGA - GRIB FIELD - "GRIB" THRU "7777" CHAR*1 -C -C OUTPUT ARGUMENT LIST: -C DATA - ARRAY CONTAINING DATA ELEMENTS -C KPDS - ARRAY CONTAINING PDS ELEMENTS. (VERSION 0) -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - GRIB SPECIFICATION EDITION NUMBER -C KPDS - ARRAY CONTAINING PDS ELEMENTS. (VERSION 1) -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - TOTAL LENGTH OF GRIB MESSAGE (INCLUDING SECTION 0) -C KGDS - ARRAY CONTAINING GDS ELEMENTS. -C (1) - DATA REPRESENTATION TYPE -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUNDINAL DIRECTION OF INCREMENT -C (11) - SCANNING MODE FLAG -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESERVED -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LONGIT DIR INCREMENT -C (10) - LATIT DIR INCREMENT -C (11) - SCANNING MODE FLAG -C (12) - LATITUDE INTERSECTION -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESERVED -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C KBMS - BITMAP DESCRIBING LOCATION OF OUTPUT ELEMENTS. -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS -C (4) - LENGTH OF GDS -C (5) - LENGTH OF BMS -C (6) - LENGTH OF BDS -C (7) - VALUE OF CURRENT BYTE -C (8) - UNUSED -C (9) - GRIB START BYTE NR -C (10) - GRIB/GRID ELEMENT COUNT -C KRET - FLAG INDICATING QUALITY OF COMPLETION -C -C REMARKS: VALUES FOR RETURN FLAG (KRET) -C KRET = 0 - NORMAL RETURN, NO ERRORS -C = 1 - 'GRIB' NOT FOUND IN FIRST 100 CHARS -C = 2 - '7777' NOT IN CORRECT LOCATION -C = 3 - UNPACKED FIELD IS LARGER THAN 32768 -C = 4 - GDS/ GRID NOT ONE OF CURRENTLY ACCEPTED VALUES -C = 5 - GRID NOT CURRENTLY AVAIL FOR CENTER INDICATED -C = 8 - TEMP GDS INDICATED, BUT GDS FLAG IS OFF -C = 9 - GDS INDICATES SIZE MISMATCH WITH STD GRID -C =10 - INCORRECT CENTER INDICATOR -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C 4 AUG 1988 -C W3AI08 -C -C -C GRIB UNPACKING ROUTINE -C -C -C THIS ROUTINE WILL UNPACK A 'GRIB' FIELD TO THE EXACT GRID -C TYPE SPECIFIED IN THE MESSAGE, RETURN A BIT MAP AND MAKE THE -C VALUES OF THE PRODUCT DEFINITION SEC (PDS) AND THE GRID -C DESCRIPTION SEC (GDS) AVAILABLE IN RETURN ARRAYS. -C SEE "GRIB - THE WMO FORMAT FOR THE STORAGE OF WEATHER PRODUCT -C INFORMATION AND THE EXCHANGE OF WEATHER PRODUCT MESSAGES IN -C GRIDDED BINARY FORM" DATED JULY 1, 1988 BY JOHN D. STACKPOLE -C DOC, NOAA, NWS, NATIONAL METEOROLOGICAL CENTER. -C -C THE CALL TO THE GRIB UNPACKING ROUTINE IS AS FOLLOWS: -C -C CALL W3AI08(MSGA,KPDS,KGDS,LBMS,DATA,KPTR,KRET) -C -C INPUT: -C -C MSGA = CONTAINS THE GRIB MESSAGE TO BE UNPACKED. CHARACTERS -C "GRIB" MAY BEGIN ANYWHERE WITHIN FIRST 100 BYTES. -C -C OUTPUT: -C -C KPDS(100) INTEGER -C ARRAY TO CONTAIN THE ELEMENTS OF THE PRODUCT -C DEFINITION SEC . -C (VERSION 0) -C KPDS(1) - ID OF CENTER -C KPDS(2) - MODEL IDENTIFICATION (SEE "GRIB" TABLE 1) -C KPDS(3) - GRID IDENTIFICATION (SEE "GRIB" TABLE 2) -C KPDS(4) - GDS/BMS FLAG -C BIT DEFINITION -C 25 0 - GDS OMITTED -C 1 - GDS INCLUDED -C 26 0 - BMS OMITTED -C 1 - BMS INCLUDED -C NOTE:- LEFTMOST BIT = 1, -C RIGHTMOST BIT = 32 -C KPDS(5) - INDICATOR OF PARAMETER (SEE "GRIB" TABLE 5) -C KPDS(6) - TYPE OF LEVEL (SEE "GRIB" TABLES 6 & 7) -C KPDS(7) - HEIGHT,PRESSURE,ETC OF LEVEL -C KPDS(8) - YEAR OF CENTURY -C KPDS(9) - MONTH OF YEAR -C KPDS(10) - DAY OF MONTH -C KPDS(11) - HOUR OF DAY -C KPDS(12) - MINUTE OF HOUR -C KPDS(13) - INDICATOR OF FORECAST TIME UNIT (SEE "GRIB" -C TABLE 8) -C KPDS(14) - TIME 1 (SEE "GRIB" TABLE 8A) -C KPDS(15) - TIME 2 (SEE "GRIB" TABLE 8A) -C KPDS(16) - TIME RANGE INDICATOR (SEE "GRIB" TABLE 8A) -C KPDS(17) - NUMBER INCLUDED IN AVERAGE -C KPDS(18) - VERSION NR OF GRIB SPECIFICATION -C -C (VERSION 1) -C KPDS(1) - ID OF CENTER -C KPDS(2) - MODEL IDENTIFICATION (SEE "GRIB" TABLE 1) -C KPDS(3) - GRID IDENTIFICATION (SEE "GRIB" TABLE 2) -C KPDS(4) - GDS/BMS FLAG -C BIT DEFINITION -C 25 0 - GDS OMITTED -C 1 - GDS INCLUDED -C 26 0 - BMS OMITTED -C 1 - BMS INCLUDED -C NOTE:- LEFTMOST BIT = 1, -C RIGHTMOST BIT = 32 -C KPDS(5) - INDICATOR OF PARAMETER (SEE "GRIB" TABLE 5) -C KPDS(6) - TYPE OF LEVEL (SEE "GRIB" TABLES 6 & 7) -C KPDS(7) - HEIGHT,PRESSURE,ETC OF LEVEL -C KPDS(8) - YEAR INCLUDING CENTURY -C KPDS(9) - MONTH OF YEAR -C KPDS(10) - DAY OF MONTH -C KPDS(11) - HOUR OF DAY -C KPDS(12) - MINUTE OF HOUR -C KPDS(13) - INDICATOR OF FORECAST TIME UNIT (SEE "GRIB" -C TABLE 8) -C KPDS(14) - TIME 1 (SEE "GRIB" TABLE 8A) -C KPDS(15) - TIME 2 (SEE "GRIB" TABLE 8A) -C KPDS(16) - TIME RANGE INDICATOR (SEE "GRIB" TABLE 8A) -C KPDS(17) - NUMBER INCLUDED IN AVERAGE -C KPDS(18) - VERSION NR OF GRIB SPECIFICATION -C KPDS(19) - VERSION NR OF PARAMETER TABLE -C KPDS(20) - TOTAL LENGTH 0F GRIB MESSAGE -C (INCLUDING SECTION 0) -C KGDS(13) INTEGER -C ARRAY CONTAINING GDS ELEMENTS. -C -C KGDS(1) - DATA REPRESENTATION TYPE -C -C LATITUDE/LONGITUDE GRIDS (SEE "GRIB" TABLE 10) -C KGDS(2) - N(I) NUMBER OF POINTS ON LATITUDE -C CIRCLE -C KGDS(3) - N(J) NUMBER OF POINTS ON LONGITUDE -C CIRCLE -C KGDS(4) - LA(1) LATITUDE OF ORIGIN -C KGDS(5) - LO(1) LONGITUDE OF ORIGIN -C KGDS(6) - RESOLUTION FLAG -C BIT MEANING -C 25 0 - DIRECTION INCREMENTS NOT -C GIVEN -C 1 - DIRECTION INCREMENTS GIVEN -C KGDS(7) - LA(2) LATITUDE OF EXTREME POINT -C KGDS(8) - LO(2) LONGITUDE OF EXTREME POINT -C KGDS(9) - DI LONGITUDINAL DIRECTION INCREMENT -C KGDS(10) - REGULAR LAT/LON GRID -C DJ - LATITUDINAL DIRECTION -C INCREMENT -C GAUSSIAN GRID -C N - NUMBER OF LATITUDE CIRCLES -C BETWEEN A POLE AND THE EQUATOR -C KGDS(11) - SCANNING MODE FLAG -C BIT MEANING -C 25 0 - POINTS ALONG A LATITUDE -C SCAN FROM WEST TO EAST -C 1 - POINTS ALONG A LATITUDE -C SCAN FROM EAST TO WEST -C 26 0 - POINTS ALONG A MERIDIAN -C SCAN FROM NORTH TO SOUTH -C 1 - POINTS ALONG A MERIDIAN -C SCAN FROM SOUTH TO NORTH -C 27 0 - POINTS SCAN FIRST ALONG -C CIRCLES OF LATITUDE, THEN -C ALONG MERIDIANS -C (FORTRAN: (I,J)) -C 1 - POINTS SCAN FIRST ALONG -C MERIDIANS THEN ALONG -C CIRCLES OF LATITUDE -C (FORTRAN: (J,I)) -C -C POLAR STEREOGRAPHIC GRIDS (SEE GRIB TABLE 12) -C KGDS(2) - N(I) NR POINTS ALONG LAT CIRCLE -C KGDS(3) - N(J) NR POINTS ALONG LON CIRCLE -C KGDS(4) - LA(1) LATITUDE OF ORIGIN -C KGDS(5) - LO(1) LONGITUDE OF ORIGIN -C KGDS(6) - RESERVED -C KGDS(7) - LOV GRID ORIENTATION -C KGDS(8) - DX - X DIRECTION INCREMENT -C KGDS(9) - DY - Y DIRECTION INCREMENT -C KGDS(10) - PROJECTION CENTER FLAG -C KGDS(11) - SCANNING MODE -C -C SPHERICAL HARMONIC COEFFICIENTS (SEE "GRIB" TABLE 14) -C KGDS(2) - J PENTAGONAL RESOLUTION PARAMETER -C KGDS(3) - K PENTAGONAL RESOLUTION PARAMETER -C KGDS(4) - M PENTAGONAL RESOLUTION PARAMETER -C KGDS(5) - REPRESENTATION TYPE -C KGDS(6) - COEFFICIENT STORAGE MODE -C -C MERCATOR GRIDS -C KGDS(2) - N(I) NR POINTS ON LATITUDE CIRCLE -C KGDS(3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C KGDS(4) - LA(1) LATITUDE OF ORIGIN -C KGDS(5) - LO(1) LONGITUDE OF ORIGIN -C KGDS(6) - RESOLUTION FLAG -C KGDS(7) - LA(2) LATITUDE OF LAST GRID POINT -C KGDS(8) - LO(2) LONGITUDE OF LAST GRID POINT -C KGDS(9) - LONGIT DIR INCREMENT -C KGDS(10) - LATIT DIR INCREMENT -C KGDS(11) - SCANNING MODE FLAG -C KGDS(12) - LATITUDE INTERSECTION -C LAMBERT CONFORMAL GRIDS -C KGDS(2) - NX NR POINTS ALONG X-AXIS -C KGDS(3) - NY NR POINTS ALONG Y-AXIS -C KGDS(4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C KGDS(5) - LO1 LON OF ORIGIN (LOWER LEFT) -C KGDS(6) - RESERVED -C KGDS(7) - LOV - ORIENTATION OF GRID -C KGDS(8) - DX - X-DIR INCREMENT -C KGDS(9) - DY - Y-DIR INCREMENT -C KGDS(10) - PROJECTION CENTER FLAG -C KGDS(11) - SCANNING MODE FLAG -C KGDS(12) - LATIN 1 - FIRST LAT FROM POLE OF -C SECANT CONE INTERSECTION -C KGDS(13) - LATIN 2 - SECOND LAT FROM POLE OF -C SECANT CONE INTERSECTION -C -C LBMS(32768) LOGICAL -C ARRAY TO CONTAIN THE BIT MAP DESCRIBING THE -C PLACEMENT OF DATA IN THE OUTPUT ARRAY. IF A -C BIT MAP IS NOT INCLUDED IN THE SOURCE MESSAGE, -C ONE WILL BE GENERATED AUTOMATICALLY BY THE -C UNPACKING ROUTINE. -C -C -C DATA(32768) REAL -C THIS ARRAY WILL CONTAIN THE UNPACKED DATA POINTS. -C -C NOTE:- 32768 IS MAXIMUN FIELD SIZE ALLOWABLE -C -C KPTR(10) INTEGER -C ARRAY CONTAINING STORAGE FOR THE FOLLOWING -C PARAMETERS. -C -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS (IN BYTES) -C (4) - LENGTH OF GDS (IN BYTES) -C (5) - LENGTH OF BMS (IN BYTES) -C (6) - LENGTH OF BDS (IN BYTES) -C (7) - USED BY UNPACKING ROUTINE -C (8) - NUMBER OF DATA POINTS FOR GRID -C (9) - "GRIB" CHARACTERS START IN BYTE NUMBER -C (10) - USED BY UNPACKING ROUTINE -C -C -C KRET INTEGER -C THIS VARIABLE WILL CONTAIN THE RETURN INDICATOR. -C -C 0 - NO ERRORS DETECTED. -C -C 1 - 'GRIB' NOT FOUND IN FIRST 100 -C CHARACTERS. -C -C 2 - '7777' NOT FOUND, EITHER MISSING OR -C TOTAL OF SEC COUNTS OF INDIVIDUAL -C SEC'S IS INCORRECT. -C -C 3 - UNPACKED FIELD IS LARGER THAN 32768. -C -C 4 - IN GDS, DATA REPRESENTATION TYPE -C NOT ONE OF THE CURRENTLY ACCEPTABLE -C VALUES. SEE "GRIB" TABLE 9. VALUE -C OF INCORRECT TYPE RETURNED IN KGDS(1). -C -C 5 - GRID INDICATED IN KPDS(3) IS NOT -C AVAILABLE FOR THE CENTER INDICATED IN -C KPDS(1) AND NO GDS SENT. -C -C 7 - VERSION INDICATED IN KPDS(18) HAS NOT -C YET BEEN INCLUDED IN THE DECODER. -C -C 8 - GRID IDENTIFICATION = 255 (NOT STANDARD -C GRID) BUT FLAG INDICATING PRESENCE OF -C GDS IS TURNED OFF. NO METHOD OF -C GENERATING PROPER GRID. -C -C 9 - PRODUCT OF KGDS(2) AND KGDS(3) DOES NOT -C MATCH STANDARD NUMBER OF POINTS FOR THIS -C GRID (FOR OTHER THAN SPECTRALS). THIS -C WILL OCCUR ONLY IF THE GRID. -C IDENTIFICATION, KPDS(3), AND A -C TRANSMITTED GDS ARE INCONSISTENT. -C -C 10 - CENTER INDICATOR WAS NOT ONE INDICATED -C IN "GRIB" TABLE 1. PLEASE CONTACT AD -C PRODUCTION MANAGEMENT BRANCH (W/NMC42) -C IF THIS ERROR IS ENCOUNTERED. -C -C -C -C LIST OF TEXT MESSAGES FROM CODE -C -C -C W3AI08/AI082 -C -C 'HAVE ENCOUNTERED A NEW GRID FOR NMC, PLEASE NOTIFY -C AUTOMATION DIVISION, PRODUCTION MANAGEMENT BRANCH -C (W/NMC42)' -C -C 'HAVE ENCOUNTERED A NEW GRID FOR ECMWF, PLEASE NOTIFY -C AUTOMATION DIVISION, PRODUCTION MANAGEMENT BRANCH -C (W/NMC42)' -C -C 'HAVE ENCOUNTERED A NEW GRID FOR U.K. METEOROLOGICAL -C OFFICE, BRACKNELL. PLEASE NOTIFY AUTOMATION DIVISION, -C PRODUCTION MANAGEMENT BRANCH (W/NMC42)' -C -C 'HAVE ENCOUNTERED A NEW GRID FOR FNOC, PLEASE NOTIFY -C AUTOMATION DIVISION, PRODUCTION MANAGEMENT BRANCH -C (W/NMC42)' -C -C -C W3AI08/AI083 -C -C 'POLAR STEREO PROCESSING NOT AVAILABLE' * -C -C W3AI08/AI084 -C -C 'WARNING - BIT MAP MAY NOT BE ASSOCIATED WITH SPHERICAL -C COEFFICIENTS' -C -C -C W3AI08/AI087 -C -C 'NO CURRENT LISTING OF FNOC GRIDS' * -C -C -C * WILL BE AVAILABLE IN NEXT UPDATE -C *************************************************************** -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C BIT MAP - LOGICAL KBMS(*) -C -C ELEMENTS OF PRODUCT DESCRIPTION SEC (PDS) - INTEGER KPDS(*) -C ELEMENTS OF GRID DESCRIPTION SEC (PDS) - INTEGER KGDS(*) -C -C CONTAINER FOR GRIB GRID - REAL DATA(*) -C -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C -C ***************************************************************** -C 1.0 LOCATE BEGINNING OF 'GRIB' MESSAGE -C FIND 'GRIB' CHARACTERS -C 2.0 USE COUNTS IN EACH DESCRIPTION SEC TO DETERMINE -C IF '7777' IS IN PROPER PLACE. -C 3.0 PARSE PRODUCT DEFINITION SECTION. -C 4.0 PARSE GRID DESCRIPTION SEC (IF INCLUDED) -C 5.0 PARSE BIT MAP SEC (IF INCLUDED) -C 6.0 USING INFORMATION FROM PRODUCT DEFINITION, GRID -C DESCRIPTION, AND BIT MAP SECTIONS.. EXTRACT -C DATA AND PLACE INTO PROPER ARRAY. -C ******************************************************************* -C -C MAIN DRIVER -C -C ******************************************************************* - KPTR(10) = 0 -C SEE IF PROPER 'GRIB' KEY EXISTS, THEN -C USING SEC COUNTS, DETERMINE IF '7777' -C IS IN THE PROPER LOCATION -C - CALL AI081(MSGA,KPTR,KPDS,KRET) - IF (KRET.NE.0) GO TO 900 -C -C PARSE PARAMETERS FROM PRODUCT DESCRIPTION SECTION -C - IF (KPDS(18).EQ.0) THEN - CALL AI082(MSGA,KPTR,KPDS,KRET) - ELSE IF (KPDS(18).EQ.1) THEN - CALL AI082A(MSGA,KPTR,KPDS,KRET) - ELSE - PRINT *,'GRIB EDITION',KPDS(18),' NOT PROGRAMMED FOR' - KRET = 7 - GO TO 900 - END IF - IF (KRET.NE.0) GO TO 900 -C -C EXTRACT NEW GRID DESCRIPTION -C - CALL AI083(MSGA,KPTR,KPDS,KGDS,KRET) - IF (KRET.NE.0) GO TO 900 -C -C EXTRACT OR GENERATE BIT MAP -C - CALL AI084(MSGA,KPTR,KPDS,KGDS,KBMS,KRET) - IF (KRET.NE.0) GO TO 900 -C -C USING INFORMATION FROM PDS, BMS AND BIT DATA SEC , -C EXTRACT AND SAVE IN GRIB GRID, ALL DATA ENTRIES. -C - IF (KPDS(18).EQ.0) THEN - CALL AI085(MSGA,KPTR,KPDS,KBMS,DATA,KRET) - ELSE IF (KPDS(18).EQ.1) THEN - CALL AI085A(MSGA,KPTR,KPDS,KBMS,DATA,KRET) - ELSE - PRINT *,'AI085 NOT PROGRAMMED FOR VERSION NR',KPDS(18) - KRET = 7 - END IF -C - 900 RETURN - END - SUBROUTINE AI081(MSGA,KPTR,KPDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AI081 FIND 'GRIB' CHARS & RESET POINTERS -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 88-01-20 -C -C ABSTRACT: FIND 'GRIB; CHARACTERS AND SET POINTERS TO THE NEXT -C BYTE FOLLOWING 'GRIB'. IF THEY EXIST EXTRACT COUNTS FROM GDS AND -C BMS. EXTRACT COUNT FROM BDS. DETERMINE IF SUM OF COUNTS ACTUALLY -C PLACES TERMINATOR '7777' AT THE CORRECT LOCATION. -C -C PROGRAM HISTORY LOG: -C 88-01-20 CAVANAUGH -C 90-09-01 R.E.JONES CHANGE'S FOR ANSI FORTRAN -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C -C USAGE: CALL AI081(MSGA,KPTR,KPDS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - GRIB FIELD - "GRIB" THRU "7777" -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS -C (4) - LENGTH OF GDS -C (5) - LENGTH OF BMS -C (6) - LENGTH OF BDS -C (7) - VALUE OF CURRENT BYTE -C (8) - UNUSED -C (9) - GRIB START BYTE -C (10) - GRIB/GRID ELEMENT COUNT -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR OF CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C KPTR - SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C ERROR RETURNS -C KRET = 1 - NO 'GRIB' -C 2 - NO '7777' OR MISLOCATED (BY COUNTS) -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C PRODUCT DESCRIPTION SECTION DATA. - INTEGER KPDS(*) -C - INTEGER KRET -C -C DATA MASK40/Z00000040/ -C DATA MASK80/Z00000080/ -C - DATA MASK40/64/ - DATA MASK80/128/ -C -C ****************************************************************** - KRET = 0 -C ------------------- FIND 'GRIB' KEY - DO 100 I = 1, 105 - IF (MOVA2I(MSGA(I )).NE.71) GO TO 100 - IF (MOVA2I(MSGA(I+1)).NE.82) GO TO 100 - IF (MOVA2I(MSGA(I+2)).NE.73) GO TO 100 - IF (MOVA2I(MSGA(I+3)).NE.66) GO TO 100 - KPTR(9) = I - GO TO 200 - 100 CONTINUE - KRET = 1 - RETURN -C - 200 CONTINUE - IS = KPTR(9) -C ------------------- HAVE 'GRIB' KEY - KCNT = 0 -C --------------- EXTRACT COUNT FROM PDS OR GRIB - ISS = IS + 4 - DO 300 I = 0, 2 - KCNT = KCNT * 256 + MOVA2I(MSGA(I+ISS)) - 300 CONTINUE -C -C TEST FOR VERSION NUMBER OF PDS 0 OR 1 -C - IF (KCNT.EQ.24) THEN - KPTR(3) = KCNT - IGRIBL = 4 -C -C --------------- EDITION NR OF GRIB SPECIFICATION, VERSION 0 -C - KPDS(18) = MOVA2I(MSGA(ISS + 3)) - ELSE - IGRIBL = 8 - ISS = IS + IGRIBL -C --------------- EDITION NR OF GRIB SPECIFICATION, VERSION 1 - KPDS(18) = MOVA2I(MSGA(IS + 7)) -C -C --------------- PARAMETER TABLE VERSION NUMBER FOR INTERNATIONAL -C EXCHANGE (CURRENTLY NO. 1) -C - KPDS(19) = MOVA2I(MSGA(ISS + 3)) -C -C ---------------- SAVE TOTAL LENGTH OF MESSAGE (INCLUDING SECTION 0) -C - KPDS(20) = KCNT -C -C --------------- EXTRACT COUNT FROM PDS VERSION 1 -C - KCNT = 0 - DO 400 I = 0, 2 - KCNT = KCNT * 256 + MOVA2I(MSGA(I+ISS)) - 400 CONTINUE - KPTR(3) = KCNT - ENDIF -C -C --------------- GET GDS, BMS INDICATOR -C - KPDS(4) = MOVA2I(MSGA(ISS+7)) -C -C READY FOR NEXT SECTION -C - KPTR(4) = 0 - KPTR(5) = 0 - IF (IAND(KPDS(4),MASK80).EQ.0) GO TO 600 -C -C --------------- EXTRACT COUNT FROM GDS -C - ISS = KPTR(3) + IS + IGRIBL - KCNT = 0 - DO 500 I = 0, 2 - KCNT = KCNT * 256 + MOVA2I(MSGA(I+ISS)) - 500 CONTINUE - KPTR(4) = KCNT - 600 CONTINUE - IF (IAND(KPDS(4),MASK40).EQ.0) GO TO 800 -C -C ---------------- EXTRACT COUNT FROM BMS -C - ISS = KPTR(3) + KPTR(4) + IS + IGRIBL - KCNT = 0 - DO 700 I = 0, 2 - KCNT = KCNT * 256 + MOVA2I(MSGA(I+ISS)) - 700 CONTINUE - KPTR(5) = KCNT -C -C --------------- EXTRACT COUNT FROM BDS -C - 800 CONTINUE - KCNT = 0 - ISS = KPTR(3) + KPTR(4) + KPTR(5) + IS + IGRIBL - DO 900 I = 0, 2 - KCNT = KCNT * 256 + MOVA2I(MSGA(I+ISS)) - 900 CONTINUE - KPTR(6) = KCNT -C -C --------------- TEST FOR '7777' -C - ISS = KPTR(3) + KPTR(4) + KPTR(5) + KPTR(6) + IS + IGRIBL - KRET = 0 - DO 1000 I = 0, 3 - IF (MOVA2I(MSGA(I+ISS)).EQ.55) THEN - GO TO 1000 - ELSE - KRET = 2 - RETURN - END IF - 1000 CONTINUE - RETURN - END - SUBROUTINE AI082(MSGA,KPTR,KPDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AI082 GATHER INFO FROM PGM DESC SECTION -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 88-01-20 -C -C ABSTRACT: EXTRACT INFORMATION FROM THE PRODUCT DESCRIPTION -C SEC , AND GENERATE LABEL INFORMATION TO PERMIT STORAGE -C IN OFFICE NOTE 84 FORMAT. -C -C PROGRAM HISTORY LOG: -C 88-01-20 CAVANAUGH -C 90-09-01 R.E.JONES CHANGE'S FOR ANSI FORTRAN -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C 90-12-05 R.E.JONES CHANGE'S FOR GRIB NOV. 21,1990 -C -C USAGE: CALL AI082(MSGA,KPTR,KPDS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS -C (4) - LENGTH OF GDS -C (5) - LENGTH OF BMS -C (6) - LENGTH OF PDS -C (7) - VALUE OF CURRENT BYTE -C (8) - UNUSED -C (9) - GRIB START BYTE NR -C (10) - GRIB/GRID ELEMENT COUNT -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR OF CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NUMBER OF GRIB SPEFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - TOTAL LENGTH OF GRIB MESSAGE (INCLUDING SECTION 0) -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C ERROR RETURN = 0 - NO ERRORS -C = 8 - TEMP GDS INDICATED, BUT NO GDS -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C PRODUCT DESCRIPTION SECTION ENTRIES - INTEGER KPDS(*) -C - INTEGER KRET -C -C -------------------- COLLECT PDS VALUES -C KPDS(1) - ID OF CENTER -C KPDS(2) - MODEL IDENTIFICATION -C KPDS(3) - GRID IDENTIFICATION -C KPDS(4) - GDS/BMS FLAG -C KPDS(5) - INDICATOR OF PARAMETER -C ----------- KPDS(6) - TYPE OF LEVEL - IS = KPTR(9) - ISS = IS + 8 - DO 200 I = 0, 5 - KPDS(I+1) = MOVA2I(MSGA(I+ISS)) - 200 CONTINUE - IF (KPDS(3).NE.255) GO TO 250 - IF (IAND(KPDS(4),128).NE.0) GO TO 250 - KRET = 8 - RETURN - 250 CONTINUE - ISS = IS + 14 - KPDS(7) = 0 - DO 300 I = 0, 1 - KPDS(7) = KPDS(7) * 256 + MOVA2I(MSGA(I+ISS)) - 300 CONTINUE -C ----------- KPDS(8) - YEAR OF CENTURY -C KPDS(9) - MONTH OF YEAR -C KPDS(10) - DAY OF MONTH -C KPDS(11) - HOUR OF DAY -C KPDS(12) - MINUTE OF HOUR -C KPDS(13) - INDICATOR OF FORECAST TIME UNIT -C KPDS(14) - TIME RANGE 1 -C KPDS(15) - TIME RANGE 2 -C ----------- KPDS(16) - TIME RANGE FLAG -C - ISS = IS + 16 - DO 400 I = 0, 7 - KPDS(I+8) = MOVA2I(MSGA(I+ISS)) - 400 CONTINUE -C ----------- KPDS(17) - NUMBER INCLUDED IN AVERAGE - ISS = IS + 25 - KPDS(17) = 0 - DO 500 I = 0, 1 - KPDS(17) = KPDS(17) * 256 + MOVA2I(MSGA(I+ISS)) - 500 CONTINUE -C -----------SKIP OVER SOURCE BYTE 24 -C ----------- TEST FOR NEW GRID - IF (IAND(KPDS(4),128).NE.0) THEN - IF (IAND(KPDS(4),64).NE.0) THEN - IF (KPDS(3).NE.255) THEN - IF (KPDS(1).EQ.7) THEN - IF (KPDS(3).GE.21.AND.KPDS(3).LE.26) THEN - ELSE IF (KPDS(3).EQ.50) THEN - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - ELSE IF (KPDS(3).EQ.70) THEN - ELSE IF (KPDS(3).GE.85.AND.KPDS(3).LE.86) THEN - ELSE IF (KPDS(3).GE.100.AND.KPDS(3).LE.103) THEN - ELSE IF (KPDS(3).GE.201.AND.KPDS(3).LE.214) THEN - ELSE - PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', - * ' NMC' - PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' - PRINT *,' PRODUCTION MANAGEMENT BRANCH' - PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.98) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.16) THEN - ELSE - PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', - * ' ECMWF' - PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' - PRINT *,' PRODUCTION MANAGEMENT BRANCH' - PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.74) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.12) THEN - ELSE IF (KPDS(3).GE.21.AND.KPDS(3).LE.26)THEN - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - ELSE IF (KPDS(3).EQ.70) THEN - ELSE - PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', - * ' U.K. MET OFFICE, BRACKNELL' - PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' - PRINT *,' PRODUCTION MANAGEMENT BRANCH' - PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.58) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.12) THEN - ELSE - PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', - * ' FNOC,' - PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' - PRINT *,' PRODUCTION MANAGEMENT BRANCH' - PRINT *,' W/NMC42)' - END IF - END IF - END IF - END IF - END IF - RETURN - END - SUBROUTINE AI082A(MSGA,KPTR,KPDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AI082A GATHER INFO FROM PGM DESC SECTION -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 88-01-20 -C -C ABSTRACT: EXTRACT INFORMATION FROM THE PRODUCT DESCRIPTION SECTION -C (VERSION 1) -C -C PROGRAM HISTORY LOG: -C 89-11-20 CAVANAUGH -C 90-09-01 R.E.JONES CHANGE'S FOR ANSI FORTRAN -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C 90-12-05 R.E.JONES CHANGE'S FOR GRIB NOV. 21,1990 -C -C USAGE: CALL AI082A(MSGA,KPTR,KPDS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS -C (4) - LENGTH OF GDS -C (5) - LENGTH OF BMS -C (6) - LENGTH OF PDS -C (7) - VALUE OF CURRENT BYTE -C (8) - UNUSED -C (9) - GRIB START BYTE NR -C (10) - GRIB/GRID ELEMENT COUNT -C -C OUTPUT ARGUMENT LIST: -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR (INCLUDING CENTURY) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - TOTAL BYTE COUNT FOR SOURCE MESSAGE -C -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C SOURCE PDS STRUCTURE (VERSION 1) -C 1-3 - LENGTH OF PDS SECTION IN BYTES -C 4 - PARAMETER TABLE VERSION NO. FOR INTERNATIONAL -C EXCHANGE (CRRENTLY NO. 1) -C 5 - CENTER ID -C 6 - MODEL ID -C 7 - GRID ID -C 8 - FLAG FOR GDS/BMS -C 9 - INDICATOR FOR PARAMETER -C 10 - INDICATOR FOR TYPE OF LEVEL -C 11-12 - HEIGHT, PRESSURE OF LEVEL -C 13 - YEAR OF CENTURY -C 14 - MONTH -C 15 - DAY -C 16 - HOUR -C 17 - MINUTE -C 18 - FORECAST TIME UNIT -C 19 - P1 - PD OF TIME -C 20 - P2 - PD OF TIME -C 21 - TIME RANGE INDICATOR -C 22-23 - NUMBER IN AVERAGE -C 24 - NUMBER MISG FROM AVERAGES -C 25 - CENTURY -C 26 - INDICATOR OF PARAMETER IN LOCALLY RE-DEFINED -C PARAMETER TABLE. -C 27-28 - UNITS DECIMAL SCALE FACTOR (D) -C 29-40 - RESERVED: NEED NOT BE PRESENT -C 41-NN - NATIONAL USE -C . -C -C ERROR RETURN = 0 - NO ERRORS -C = 8 - TEMP GDS INDICATED, BUT NO GDS -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C PRODUCT DESCRIPTION SECTION ENTRIES - INTEGER KPDS(*) -C - INTEGER KRET -C - IS = KPTR(9) - IGRIBL = 8 -C -------------------- COLLECT PDS VALUES -C KPDS(1) - ID OF CENTER -C KPDS(2) - MODEL IDENTIFICATION -C KPDS(3) - GRID IDENTIFICATION -C KPDS(4) - GDS/BMS FLAG -C KPDS(5) - INDICATOR OF PARAMETER -C ----------- KPDS(6) - TYPE OF LEVEL - ISS = IS + IGRIBL + 4 - DO 200 I = 0, 5 - KPDS(I+1) = MOVA2I(MSGA(I+ISS)) - 200 CONTINUE - IF (KPDS(3).NE.255) GO TO 250 - IF (IAND(KPDS(4),128).NE.0) GO TO 250 - KRET = 8 - RETURN - 250 CONTINUE -C HEIGHT, PRESS OF LEVEL - ISS = IS + IGRIBL + 10 - KPDS(7) = 0 - DO 300 I = 0, 1 - KPDS(7) = KPDS(7) * 256 + MOVA2I(MSGA(I+ISS)) - 300 CONTINUE -C -C ----------- KPDS(8) - YEAR (INCLUDING CENTURY) -C - ISS = IS + IGRIBL + 12 - ICEN = IS + IGRIBL + 24 -C - KPDS(8) = MOVA2I(MSGA(ICEN)) * 100 + MOVA2I(MSGA(ISS)) -C -C KPDS(9) - MONTH OF YEAR -C KPDS(10) - DAY OF MONTH -C KPDS(11) - HOUR OF DAY -C KPDS(12) - MINUTE OF HOUR -C KPDS(13) - INDICATOR OF FORECAST TIME UNIT -C KPDS(14) - TIME RANGE 1 -C KPDS(15) - TIME RANGE 2 -C ----------- KPDS(16) - TIME RANGE FLAG -C - ISS = IS + IGRIBL + 13 - DO 400 I = 0, 7 - KPDS(I+9) = MOVA2I(MSGA(I+ISS)) - 400 CONTINUE -C ----------- KPDS(17) - NUMBER INCLUDED IN AVERAGE - ISS = IS + IGRIBL + 21 - KPDS(17) = 0 - DO 500 I = 0, 1 - KPDS(17) = KPDS(17) * 256 + MOVA2I(MSGA(I+ISS)) - 500 CONTINUE -C -----------SKIP OVER SOURCE BYTE 28 -C ----------- TEST FOR NEW GRID - IF (IAND(KPDS(4),128).NE.0) THEN - IF (IAND(KPDS(4),64).NE.0) THEN - IF (KPDS(3).NE.255) THEN - IF (KPDS(1).EQ.7) THEN - IF (KPDS(3).GE.21.AND.KPDS(3).LE.26)THEN - ELSE IF (KPDS(3).EQ.50) THEN - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - ELSE IF (KPDS(3).EQ.70) THEN - ELSE IF (KPDS(3).GE.85.AND.KPDS(3).LE.86) THEN - ELSE IF (KPDS(3).GE.100.AND.KPDS(3).LE.103) THEN - ELSE IF (KPDS(3).GE.201.AND.KPDS(3).LE.214) THEN - ELSE - PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', - * ' NMC' - PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' - PRINT *,' PRODUCTION MANAGEMENT BRANCH' - PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.98) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.16) THEN - ELSE - PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', - * ' ECMWF' - PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' - PRINT *,' PRODUCTION MANAGEMENT BRANCH' - PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.74) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.12) THEN - ELSE IF (KPDS(3).GE.21.AND.KPDS(3).LE.26)THEN - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - ELSE IF (KPDS(3).EQ.70) THEN - ELSE - PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', - * ' U.K. MET OFFICE, BRACKNELL' - PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' - PRINT *,' PRODUCTION MANAGEMENT BRANCH' - PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.58) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.12) THEN - ELSE - PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', - * ' FNOC,' - PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' - PRINT *,' PRODUCTION MANAGEMENT BRANCH' - PRINT *,' W/NMC42)' - END IF - END IF - END IF - END IF - END IF - RETURN - END - SUBROUTINE AI083(MSGA,KPTR,KPDS,KGDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AI083 EXTRACT INFO FROM GRIB-GDS -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 88-01-20 -C -C ABSTRACT: EXTRACT INFORMATION ON UNLISTED GRID TO ALLOW -C CONVERSION TO OFFICE NOTE 84 FORMAT. -C -C PROGRAM HISTORY LOG: -C 88-01-20 CAVANAUGH -C 89-03-16 CAVANAUGH ADDED MERCATOR & LAMBERT CONFORMAL PROCESSING -C 89-07-12 CAVANAUGH CORRECTED CHANGE ENTERED 89-03-16 REORDERING -C PROCESSING FOR LAMBERT CONFORMAL AND MERCATOR -C GRIDS. -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C -C USAGE: CALL AI083(MSGA,KPTR,KPDS,KGDS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS -C (4) - LENGTH OF GDS -C (5) - LENGTH OF BMS -C (6) - LENGTH OF BDS -C (7) - VALUE OF CURRENT BYTE -C (8) - UNUSED -C (9) - GRIB START BYTE NR -C (10) - GRIB/GRID ELEMENT COUNT -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR OF CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KGDS - ARRAY CONTAINING GDS ELEMENTS. -C (1) - DATA REPRESENTATION TYPE -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION OF INCREMENT -C (11) - SCANNING MODE FLAG -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESERVED -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LONGIT DIR INCREMENT -C (10) - LATIT DIR INCREMENT -C (11) - SCANNING MODE FLAG -C (12) - LATITUDE INTERSECTION -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESERVED -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C KRET = 0 -C = 4 - DATA REPRESENTATION TYPE NOT CURRENTLY ACCEPTABLE -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C ************************************************************ -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C -C ARRAY GDS ELEMENTS - INTEGER KGDS(*) -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C ARRAY OF PDS ELEMENTS - INTEGER KPDS(*) -C - INTEGER KRET -C -C DATA MSK80 /Z00000080/ -C - DATA MSK80 /128/ -C ******************************************************** -C IF FLAG IN PDS INDICATE THAT THERE IS NO GDS , -C RETURN IMMEDIATELY -C ************************************************************ - IF (IAND(KPDS(4),MSK80).EQ.0) GO TO 900 -C ------------------- BYTE 1-3 COUNT - IS = KPTR(9) - IF (KPDS(18).EQ.0) THEN - IGRIBL = 4 - ELSE - IGRIBL = 8 - ENDIF - ISS = IS + KPTR(3) + IGRIBL -C ------------------- BYTE 4 NUMBER OF UNUSED BITS AT END OF SEC -C ------------------- BYTE 5 RESERVED -C ------------------- BYTE 6 DATA REPRESENTATION TYPE - KGDS(1) = MOVA2I(MSGA(ISS+5)) -C ------------------- DIVERT TO PROCESS CORRECT TYPE - IF (KGDS(1).EQ.0) THEN - GO TO 1000 - ELSE IF (KGDS(1).EQ.1) THEN - GO TO 4000 - ELSE IF (KGDS(1).EQ.2.OR.KGDS(1).EQ.5) THEN - GO TO 2000 - ELSE IF (KGDS(1).EQ.3) THEN - GO TO 5000 - ELSE IF (KGDS(1).EQ.4) THEN - GO TO 1000 - ELSE IF (KGDS(1).EQ.50) THEN - GO TO 3000 - ELSE -C MARK AS GDS/ UNKNOWN DATA REPRESENTATION TYPE - KRET = 4 - GO TO 900 - END IF -C -C ------------------- LATITUDE/LONGITUDE GRIDS -C -C ------------------- BYTE 7-8 NR OF POINTS ALONG LATITUDE CIRCLE - 1000 KGDS(2) = 0 - DO 1005 I = 0, 1 - KGDS(2) = KGDS(2) * 256 + MOVA2I(MSGA(I+ISS+6)) - 1005 CONTINUE -C ------------------- BYTE 9-10 NR OF POINTS ALONG LONG MERIDIAN - KGDS(3) = 0 - DO 1010 I = 0, 1 - KGDS(3) = KGDS(3) * 256 + MOVA2I(MSGA(I+ISS+8)) - 1010 CONTINUE -C ------------------- BYTE 11-13 LATITUE OF ORIGIN - KGDS(4) = 0 - DO 1020 I = 0, 2 - KGDS(4) = KGDS(4) * 256 + MOVA2I(MSGA(I+ISS+10)) - 1020 CONTINUE - IF (IAND(KGDS(4),8388608).NE.0) THEN - KGDS(4) = IAND(KGDS(4),8388607) * (-1) - END IF -C ------------------- BYTE 14-16 LONGITUDE OF ORIGIN - KGDS(5) = 0 - DO 1030 I = 0, 2 - KGDS(5) = KGDS(5) * 256 + MOVA2I(MSGA(I+ISS+13)) - 1030 CONTINUE - IF (IAND(KGDS(5),8388608).NE.0) THEN - KGDS(5) = - IAND(KGDS(5),8388607) - END IF -C ------------------- BYTE 17 RESOLUTION FLAG - KGDS(6) = MOVA2I(MSGA(ISS+16)) -C ------------------- BYTE 18-20 LATITUDE OF LAST GRID POINT - KGDS(7) = 0 - DO 1040 I = 0, 2 - KGDS(7) = KGDS(7) * 256 + MOVA2I(MSGA(I+ISS+17)) - 1040 CONTINUE - IF (IAND(KGDS(7),8388608).NE.0) THEN - KGDS(7) = - IAND(KGDS(7),8388607) - END IF -C ------------------- BYTE 21-23 LONGITUDE OF LAST GRID POINT - KGDS(8) = 0 - DO 1050 I = 0, 2 - KGDS(8) = KGDS(8) * 256 + MOVA2I(MSGA(I+ISS+20)) - 1050 CONTINUE - IF (IAND(KGDS(8),8388608).NE.0) THEN - KGDS(8) = - IAND(KGDS(8),8388607) - END IF -C ------------------- BYTE 24-25 LATITUDINAL DIR INCREMENT - KGDS(9) = 0 - DO 1060 I = 0, 1 - KGDS(9) = KGDS(9) * 256 + MOVA2I(MSGA(I+ISS+23)) - 1060 CONTINUE -C ------------------- BYTE 26-27 IF REGULAR LAT/LON GRID -C HAVE LONGIT DIR INCREMENT -C ELSE IF GAUSSIAN GRID -C HAVE NR OF LAT CIRCLES -C BETWEEN POLE AND EQUATOR - KGDS(10) = 0 - DO 1070 I = 0, 1 - KGDS(10) = KGDS(10) * 256 + MOVA2I(MSGA(I+ISS+25)) - 1070 CONTINUE -C ------------------- BYTE 28 SCANNING MODE FLAGS - KGDS(11) = MOVA2I(MSGA(ISS+27)) -C ------------------- BYTE 29-32 RESERVED -C ------------------- - GO TO 900 -C ------------------- -C ' POLAR STEREO PROCESSING ' -C -C ------------------- BYTE 7-8 NR OF POINTS ALONG X=AXIS - 2000 KGDS(2) = 0 - DO 2005 I = 0, 1 - KGDS(2) = KGDS(2) * 256 + MOVA2I(MSGA(I+ISS+6)) - 2005 CONTINUE -C ------------------- BYTE 9-10 NR OF POINTS ALONG Y-AXIS - KGDS(3) = 0 - DO 2010 I = 0, 1 - KGDS(3) = KGDS(3) * 256 + MOVA2I(MSGA(I+ISS+8)) - 2010 CONTINUE -C ------------------- BYTE 11-13 LATITUDE OF ORIGIN - KGDS(4) = 0 - DO 2020 I = 0, 2 - KGDS(4) = KGDS(4) * 256 + MOVA2I(MSGA(I+ISS+10)) - 2020 CONTINUE - IF (IAND(KGDS(4),8388608).NE.0) THEN - KGDS(4) = - IAND(KGDS(4),8388607) - END IF -C ------------------- BYTE 14-16 LONGITUDE OF ORIGIN - KGDS(5) = 0 - DO 2030 I = 0, 2 - KGDS(5) = KGDS(5) * 256 + MOVA2I(MSGA(I+ISS+13)) - 2030 CONTINUE - IF (IAND(KGDS(5),8388608).NE.0) THEN - KGDS(5) = - IAND(KGDS(5),8388607) - END IF -C ------------------- BYTE 17 RESERVED - KGDS(6) = MOVA2I(MSGA(ISS+16)) -C ------------------- BYTE 18-20 LOV ORIENTATION OF THE GRID - KGDS(7) = 0 - DO 2040 I = 0, 2 - KGDS(7) = KGDS(7) * 256 + MOVA2I(MSGA(I+ISS+17)) - 2040 CONTINUE - IF (IAND(KGDS(7),8388608).NE.0) THEN - KGDS(7) = - IAND(KGDS(7),8388607) - END IF -C ------------------- BYTE 21-23 DX - THE X DIRECTION INCREMENT - KGDS(8) = 0 - DO 2050 I = 0, 2 - KGDS(8) = KGDS(8) * 256 + MOVA2I(MSGA(I+ISS+20)) - 2050 CONTINUE - IF (IAND(KGDS(8),8388608).NE.0) THEN - KGDS(8) = - IAND(KGDS(8),8388607) - END IF -C ------------------- BYTE 24-26 DY - THE Y DIRECTION INCREMENT - KGDS(9) = 0 - DO 2060 I = 0, 2 - KGDS(9) = KGDS(9) * 256 + MOVA2I(MSGA(I+ISS+23)) - 2060 CONTINUE - IF (IAND(KGDS(9),8388608).NE.0) THEN - KGDS(9) = - IAND(KGDS(9),8388607) - END IF -C ------------------- BYTE 27 PROJECTION CENTER FLAG - KGDS(10) = MOVA2I(MSGA(ISS+26)) -C ------------------- BYTE 28 SCANNING MODE - KGDS(11) = MOVA2I(MSGA(ISS+27)) -C ------------------- BYTE 29-32 RESERVED -C ------------------- - GO TO 900 -C -C ------------------- GRID DESCRIPTION FOR SPHERICAL HARMONIC COEFF. -C -C ------------------- BYTE 7-8 J PENTAGONAL RESOLUTION PARAMETER - 3000 KGDS(2) = 0 - DO 3010 I = 0, 1 - KGDS(2) = KGDS(2) * 256 + MOVA2I(MSGA(I+ISS+6)) - 3010 CONTINUE -C ------------------- BYTE 9-10 K PENTAGONAL RESOLUTION PARAMETER - KGDS(3) = 0 - DO 3020 I = 0, 1 - KGDS(3) = KGDS(3) * 256 + MOVA2I(MSGA(I+ISS+8)) - 3020 CONTINUE -C ------------------- BYTE 11-12 M PENTAGONAL RESOLUTION PARAMETER - KGDS(4) = 0 - DO 3030 I = 0, 1 - KGDS(4) = KGDS(4) * 256 + MOVA2I(MSGA(I+ISS+10)) - 3030 CONTINUE -C ------------------- BYTE 13 REPRESENTATION TYPE - KGDS(5) = MOVA2I(MSGA(ISS+12)) -C ------------------- BYTE 14 COEFFICIENT STORAGE MODE - KGDS(6) = MOVA2I(MSGA(ISS+13)) -C ------------------- EMPTY FIELDS - BYTES 15 - 32 - KRET = 0 - GO TO 900 -C ------------------- PROCESS MERCATOR GRIDS -C -C ------------------- BYTE 7-8 NR OF POINTS ALONG LATITUDE CIRCLE - 4000 KGDS(2) = 0 - DO 4005 I = 0, 1 - KGDS(2) = KGDS(2) * 256 + MOVA2I(MSGA(I+ISS+6)) - 4005 CONTINUE -C ------------------- BYTE 9-10 NR OF POINTS ALONG LONG MERIDIAN - KGDS(3) = 0 - DO 4010 I = 0, 1 - KGDS(3) = KGDS(3) * 256 + MOVA2I(MSGA(I+ISS+8)) - 4010 CONTINUE -C ------------------- BYTE 11-13 LATITUE OF ORIGIN - KGDS(4) = 0 - DO 4020 I = 0, 2 - KGDS(4) = KGDS(4) * 256 + MOVA2I(MSGA(I+ISS+10)) - 4020 CONTINUE - IF (IAND(KGDS(4),8388608).NE.0) THEN - KGDS(4) = - IAND(KGDS(4),8388607) - END IF -C ------------------- BYTE 14-16 LONGITUDE OF ORIGIN - KGDS(5) = 0 - DO 4030 I = 0, 2 - KGDS(5) = KGDS(5) * 256 + MOVA2I(MSGA(I+ISS+13)) - 4030 CONTINUE - IF (IAND(KGDS(5),8388608).NE.0) THEN - KGDS(5) = - IAND(KGDS(5),8388607) - END IF -C ------------------- BYTE 17 RESOLUTION FLAG - KGDS(6) = MOVA2I(MSGA(ISS+16)) -C ------------------- BYTE 18-20 LATITUDE OF EXTREME POINT - KGDS(7) = 0 - DO 4040 I = 0, 2 - KGDS(7) = KGDS(7) * 256 + MOVA2I(MSGA(I+ISS+17)) - 4040 CONTINUE - IF (IAND(KGDS(7),8388608).NE.0) THEN - KGDS(7) = - IAND(KGDS(7),8388607) - END IF -C ------------------- BYTE 21-23 LONGITUDE OF EXTREME POINT - KGDS(8) = 0 - DO 4050 I = 0, 2 - KGDS(8) = KGDS(8) * 256 + MOVA2I(MSGA(I+ISS+20)) - 4050 CONTINUE - IF (IAND(KGDS(8),8388608).NE.0) THEN - KGDS(8) = - IAND(KGDS(8),8388607) - END IF -C ------------------- BYTE 24-25 LONGITUDE DIR INCREMENT - KGDS(9) = 0 - DO 4070 I = 0, 1 - KGDS(9) = KGDS(9) * 256 + MOVA2I(MSGA(I+ISS+23)) - 4070 CONTINUE - IF (IAND(KGDS(9),8388608).NE.0) THEN - KGDS(9) = - IAND(KGDS(9),32768) - END IF -C ------------------- BYTE 26-27 LATIT DIR INCREMENT - KGDS(10) = 0 - DO 4080 I = 0, 1 - KGDS(10) = KGDS(10) * 256 + MOVA2I(MSGA(I+ISS+25)) - 4080 CONTINUE - IF (IAND(KGDS(10),8388608).NE.0) THEN - KGDS(10) = - IAND(KGDS(10),32768) - END IF -C ------------------- BYTE 28 SCANNING MODE FLAGS - KGDS(11) = MOVA2I(MSGA(ISS+27)) -C ------------------- BYTE 29-31 INTERSECTION LATITUDE - KGDS(12) = 0 - DO 4060 I = 0, 2 - KGDS(12)= KGDS(12) * 256 + MOVA2I(MSGA(I+ISS+28)) - 4060 CONTINUE -C ------------------- BYTE 32 RESERVED -C ------------------- - GO TO 900 -C ------------------- PROCESS LAMBERT CONFORMAL -C -C ------------------- BYTE 7-8 NR OF POINTS ALONG X-AXIS - 5000 KGDS(2) = 0 - DO 5005 I = 0, 1 - KGDS(2) = KGDS(2) * 256 + MOVA2I(MSGA(I+ISS+6)) - 5005 CONTINUE -C ------------------- BYTE 9-10 NR OF POINTS ALONG Y-AXIS - KGDS(3) = 0 - DO 5010 I = 0, 1 - KGDS(3) = KGDS(3) * 256 + MOVA2I(MSGA(I+ISS+8)) - 5010 CONTINUE -C ------------------- BYTE 11-13 LATITUDE OF ORIGIN - KGDS(4) = 0 - DO 5020 I = 0, 2 - KGDS(4) = KGDS(4) * 256 + MOVA2I(MSGA(I+ISS+10)) - 5020 CONTINUE - IF (IAND(KGDS(4),8388608).NE.0) THEN - KGDS(4) = - IAND(KGDS(4),8388607) - END IF -C ------------------- BYTE 14-16 LONGITUDE OF ORIGIN (LOWER LEFT) - KGDS(5) = 0 - DO 5030 I = 0, 2 - KGDS(5) = KGDS(5) * 256 + MOVA2I(MSGA(I+ISS+13)) - 5030 CONTINUE - IF (IAND(KGDS(5),8388608).NE.0) THEN - KGDS(5) = - IAND(KGDS(5),8388607) - END IF -C ------------------- BYTE 17 RESERVED -C KGDS(6) = -C ------------------- BYTE 18-20 LOV -ORIENTATION OF GRID - KGDS(7) = 0 - DO 5040 I = 0, 2 - KGDS(7) = KGDS(7) * 256 + MOVA2I(MSGA(I+ISS+17)) - 5040 CONTINUE - IF (IAND(KGDS(7),8388608).NE.0) THEN - KGDS(7) = - IAND(KGDS(7),8388607) - END IF -C ------------------- BYTE 21-23 DX - X-DIR INCREMENT - KGDS(8) = 0 - DO 5060 I = 0, 2 - KGDS(8) = KGDS(8) * 256 + MOVA2I(MSGA(I+ISS+20)) - 5060 CONTINUE -C ------------------- BYTE 24-26 DY - Y-DIR INCREMENT - KGDS(9) = 0 - DO 5070 I = 0, 2 - KGDS(9) = KGDS(9) * 256 + MOVA2I(MSGA(I+ISS+23)) - 5070 CONTINUE -C ------------------- BYTE 27 PROJECTION CENTER FLAG - KGDS(10) = MOVA2I(MSGA(ISS+26)) -C ------------------- BYTE 28 SCANNING MODE - KGDS(11) = MOVA2I(MSGA(ISS+27)) -C ------------------- BYTE 29-31 LATIN1 - 1ST LAT FROM POLE - KGDS(12) = 0 - DO 5050 I = 0, 2 - KGDS(12)= KGDS(12)* 256 + MOVA2I(MSGA(I+ISS+28)) - 5050 CONTINUE - IF (IAND(KGDS(12),8388608).NE.0) THEN - KGDS(12) = - IAND(KGDS(12),8388607) - END IF -C ------------------- BYTE 32-34 LATIN2 - 2ND LAT FROM POLE - KGDS(13) = 0 - DO 5055 I = 0, 2 - KGDS(13)= KGDS(13)* 256 + MOVA2I(MSGA(I+ISS+31)) - 5055 CONTINUE - IF (IAND(KGDS(13),8388608).NE.0) THEN - KGDS(13) = - IAND(KGDS(13),8388607) - END IF -C ------------------- - 900 CONTINUE - RETURN - END - SUBROUTINE AI084(MSGA,KPTR,KPDS,KGDS,KBMS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AI084 EXTRACT OR GENERATE BIT MAP FOR OUTPUT -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 88-01-20 -C -C ABSTRACT: IF BIT MAP SEC IS AVAILABLE IN GRIB MESSAGE, EXTRACT -C FOR PROGRAM USE, OTHERWISE GENERATE AN APPROPRIATE BIT MAP. -C -C PROGRAM HISTORY LOG: -C 88-01-20 CAVANAUGH -C 89-02-24 CAVANAUGH INCREMENT OF POSITION IN BIT MAP WHEN BIT MAP -C WAS INCLUDED WAS HANDLED IMPROPERLY. -C CORRECTED THIS DATA. -C 89-07-12 CAVANAUGH ALTERED METHOD OF CALCULATING NR OF BITS -C IN A BIT MAP CONTAINED IN GRIB MESSAGE. -C 90-05-07 CAVANAUGH BRINGS ALL U.S. GRIDS TO -C REVISED VALUES AS OF DEC 89. -C 90-07-15 BOSTELMAN MODIIFED TO TEST -C THE GRIB BDS BYTE SIZE TO DETERMINE WHAT -C ECMWF GRID ARRAY SIZE IS TO BE SPECIFIED. -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C 90-12-05 R.E.JONES CHANGE'S FOR GRIB NOV. 21,1990 -C -C USAGE: CALL AI084(MSGA,KPTR,KPDS,KGDS,KBMS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - BUFR MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS -C (4) - LENGTH OF GDS -C (5) - LENGTH OF BMS -C (6) - LENGTH OF BDS -C (7) - VALUE OF CURRENT BYTE -C (8) - UNUSED -C (9) - GRIB START BYTE NR -C (10) - GRIB/GRID ELEMENT COUNT -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR OF CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C -C OUTPUT ARGUMENT LIST: -C KBMS - BITMAP DESCRIBING LOCATION OF OUTPUT ELEMENTS. -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C KRET = 0 - NO ERROR -C = 5 - GRID NOT AVAIL FOR CENTER INDICATED -C =10 - INCORRECT CENTER INDICATOR -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C -C BIT MAP - LOGICAL KBMS(*) -C -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(10) -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPDS(20) - INTEGER KGDS(13) -C - INTEGER KRET - INTEGER MASK(8) -C ----------------------GRID 21 AND GRID 22 ARE THE SAME - LOGICAL GRD21( 1369) -C ----------------------GRID 23 AND GRID 24 ARE THE SAME - LOGICAL GRD23( 1369) - LOGICAL GRD25( 1368) - LOGICAL GRD26( 1368) -C ----------------------GRID 27 AND GRID 28 ARE THE SAME -C ----------------------GRID 29 AND GRID 30 ARE THE SAME -C ----------------------GRID 33 AND GRID 34 ARE THE SAME - LOGICAL GRD50(1188) -C -----------------------GRID 61 AND GRID 62 ARE THE SAME - LOGICAL GRD61( 4186) -C -----------------------GRID 63 AND GRID 64 ARE THE SAME - LOGICAL GRD63( 4186) -C - DATA GRD21 /1333*.TRUE.,36*.FALSE./ - DATA GRD23 /.TRUE.,36*.FALSE.,1332*.TRUE./ - DATA GRD25 /1297*.TRUE.,71*.FALSE./ - DATA GRD26 /.TRUE.,71*.FALSE.,1296*.TRUE./ - DATA GRD50/ -C LINE 1-4 - & 7*.FALSE.,22*.TRUE.,14*.FALSE.,22*.TRUE., - & 14*.FALSE.,22*.TRUE.,14*.FALSE.,22*.TRUE.,7*.FALSE., -C LINE 5-8 - & 6*.FALSE.,24*.TRUE.,12*.FALSE.,24*.TRUE., - & 12*.FALSE.,24*.TRUE.,12*.FALSE.,24*.TRUE.,6*.FALSE., -C LINE 9-12 - & 5*.FALSE.,26*.TRUE.,10*.FALSE.,26*.TRUE., - & 10*.FALSE.,26*.TRUE.,10*.FALSE.,26*.TRUE.,5*.FALSE., -C LINE 13-16 - & 4*.FALSE.,28*.TRUE., 8*.FALSE.,28*.TRUE., - & 8*.FALSE.,28*.TRUE., 8*.FALSE.,28*.TRUE.,4*.FALSE., -C LINE 17-20 - & 3*.FALSE.,30*.TRUE., 6*.FALSE.,30*.TRUE., - & 6*.FALSE.,30*.TRUE., 6*.FALSE.,30*.TRUE.,3*.FALSE., -C LINE 21-24 - & 2*.FALSE.,32*.TRUE., 4*.FALSE.,32*.TRUE., - & 4*.FALSE.,32*.TRUE., 4*.FALSE.,32*.TRUE.,2*.FALSE., -C LINE 25-28 - & .FALSE.,34*.TRUE., 2*.FALSE.,34*.TRUE., - & 2*.FALSE.,34*.TRUE., 2*.FALSE.,34*.TRUE., .FALSE., -C LINE 29-33 - & 180*.TRUE./ - DATA GRD61 /4096*.TRUE.,90*.FALSE./ - DATA GRD63 /.TRUE.,90*.FALSE.,4095*.TRUE./ - DATA MASK /128,64,32,16,8,4,2,1/ -C DATA MSK40 /Z00000040/ - DATA MSK40 /64/ -C - IS = KPTR(9) - IF (KPDS(18).EQ.0) THEN - IGRIBL = 4 - ELSE - IGRIBL = 8 - ENDIF - ISS = IS + KPTR(3) + KPTR(4) + IGRIBL -C ********************************************************** -C IF THE FLAG IN PDS INDICATES THAT THERE IS NO BMS, -C SET BIT MAP WITH ALL BITS ON -C ELSE -C RECOVER BIT MAP -C THEN RETURN -C ********************************************************** -C ---------------- NON-STANDARD GRID - IF (KPDS(3).EQ.255) THEN - J = KGDS(2) * KGDS(3) - KPTR(10) = J - DO 600 I = 1, J - KBMS(I) = .TRUE. - 600 CONTINUE - END IF - IF (IAND(KPDS(4),MSK40).EQ.0)THEN -C PRINT *,' NO BIT MAP',MSK40,KPDS(4) - GO TO 400 - ELSE - PRINT *,' HAVE A BIT MAP' - END IF -C ---------------- FLAG INDICATING PRESENCE OF BIT MAP IS ON - IF (KGDS(1).EQ.50) THEN - PRINT *,' W3AI08/AI084 WARNING - BIT MAP MAY NOT BE', - * ' ASSOCIATED WITH SPHERICAL COEFFICIENTS' - RETURN - ENDIF -C GET NUMBER OF UNUSED BITS - IUBITS = MOVA2I(MSGA(ISS+3)) -C SEE IF BIT MAP IS CONTAINED - KFLAG = 0 - DO 150 I = 0, 1 - KFLAG = KFLAG * 256 + MOVA2I(MSGA(I+ISS+4)) - 150 CONTINUE - PRINT *,'KFLAG=',KFLAG -C ----------------- IF KFLAG = 0 PICK UP NEW BIT MAP -C ELSE -C ------------------ USE PREDEFINED BIT MAP - MAXBYT = KPTR(5) - 6 - IF (KFLAG.EQ.0) THEN -C ------------------ UTILIZE BIT MAP FROM MESSAGE - II = 1 - DO 300 I = 1, MAXBYT - KCNT = MOVA2I(MSGA(I+ISS+6)) - DO 200 K = 1, 8 - IF (IAND(KCNT,MASK(K)).NE.0) THEN - KBMS(II) = .TRUE. - ELSE - KBMS(II) = .FALSE. - END IF - II = II + 1 - 200 CONTINUE - 300 CONTINUE - KPTR(10) = 8 * (KPTR(5) - 6) - IUBITS - GO TO 900 - ELSE - PRINT *,'KFLAG SAYS USE STD BIT MAP',KFLAG - END IF -C ---------------------- PREDEFINED BIT MAP IS INDICATED -C IF GRID NUMBER DOES NOT MATCH AN -C EXISTING GRID, SET KRET TO 5 AND -C ---------------------- RETURN. - 400 CONTINUE - KRET = 0 -C ---------------------- ECMWF MAP GRIDS - IF (KPDS(1).EQ.98) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.12) THEN - J = 1073 -C*** TEST FOR FULL HEMISPHERIC GRID **** - IF (KPTR(6) .GT. 2158) J= 1369 -C*** *** **** *** *** - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 1000 I = 1, J - KBMS(I) = .TRUE. - 1000 CONTINUE - ELSE IF (KPDS(3).GE.13.AND.KPDS(3).LE.16) THEN - J = 361 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 1013 I = 1, J - KBMS(I) = .TRUE. - 1013 CONTINUE - ELSE - KRET = 5 - RETURN - END IF -C ---------------------- U.K. MET OFFICE BRACKNELL - ELSE IF (KPDS(1).EQ.74) THEN - IF (KPDS(3).EQ.21.OR.KPDS(3).EQ.22) THEN -C ----- INT'L GRIDS 21, 22 - MAP SIZE 1369 - J = 1369 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 3021 I = 1, 1369 - KBMS(I) = GRD21(I) - 3021 CONTINUE - ELSE IF (KPDS(3).EQ.23.OR.KPDS(3).EQ.24) THEN -C ----- INT'L GRIDS 23, 24 - MAP SIZE 1369 - J = 1369 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 3023 I = 1, 1369 - KBMS(I) = GRD23(I) - 3023 CONTINUE - ELSE IF (KPDS(3).EQ.25) THEN -C ----- INT'L GRID 25 - MAP SIZE 1368 - J = 1368 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 3025 I = 1, 1368 - KBMS(I) = GRD25(I) - 3025 CONTINUE - ELSE IF (KPDS(3).EQ.26) THEN -C ----- INT'L GRID 26 - MAP SIZE 1368 - J = 1368 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 3026 I = 1, 1368 - KBMS(I) = GRD26(I) - 3026 CONTINUE - ELSE IF (KPDS(3).EQ.61.OR.KPDS(3).EQ.62) THEN -C ----- INT'L GRIDS 61, 62 - MAP SIZE 4186 - J = 4186 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 3061 I = 1, 4186 - KBMS(I) = GRD61(I) - 3061 CONTINUE - ELSE IF (KPDS(3).EQ.63.OR.KPDS(3).EQ.64) THEN -C ----- INT'L GRIDS 63, 64 - MAP SIZE 4186 - J = 4186 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 3063 I = 1, 4186 - KBMS(I) = GRD63(I) - 3063 CONTINUE - ELSE IF (KPDS(3).EQ.70) THEN -C ----- U.S. GRID 70 - MAP SIZE 16380 - J = 16380 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 3070 I = 1, J - KBMS(I) = .TRUE. - 3070 CONTINUE - ELSE - KRET = 5 - RETURN - END IF -C ---------------------- FNOC NAVY - ELSE IF (KPDS(1).EQ.58) THEN - PRINT *,' NO STANDARD FNOC GRID AT THIS TIME' - RETURN -C ---------------------- U.S. GRIDS - ELSE IF (KPDS(1).EQ.7) THEN - IF (KPDS(3).EQ.5) THEN -C ----- U.S. GRID 5 - MAP SIZE 3021 - J = 3021 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2005 I = 1, J - KBMS(I) = .TRUE. - 2005 CONTINUE - ELSE IF (KPDS(3).EQ.6) THEN -C ----- U.S. GRID 6 - MAP SIZE 2385 - J = 2385 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2006 I = 1, J - KBMS(I) = .TRUE. - 2006 CONTINUE - ELSE IF (KPDS(3).EQ.21.OR.KPDS(3).EQ.22) THEN -C ----- U.S. GRIDS 21, 22 - MAP SIZE 1369 - J = 1369 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2021 I = 1, 1369 - KBMS(I) = GRD21(I) - 2021 CONTINUE - ELSE IF (KPDS(3).EQ.23.OR.KPDS(3).EQ.24) THEN -C ----- U.S GRIDS 23, 24 - MAP SIZE 1369 - J = 1369 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2023 I = 1, 1369 - KBMS(I) = GRD23(I) - 2023 CONTINUE - ELSE IF (KPDS(3).EQ.25) THEN -C ----- U.S. GRID 25 - MAP SIZE 1368 - J = 1368 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2025 I = 1, 1368 - KBMS(I) = GRD25(I) - 2025 CONTINUE - ELSE IF (KPDS(3).EQ.26) THEN -C ----- U.S.GRID 26 - MAP SIZE 1368 - J = 1368 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2026 I = 1, 1368 - KBMS(I) = GRD26(I) - 2026 CONTINUE - ELSE IF (KPDS(3).EQ.27.OR.KPDS(3).EQ.28) THEN -C ----- U.S. GRIDS 27, 28 - MAP SIZE 4225 - J = 4225 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2027 I = 1, J - KBMS(I) = .TRUE. - 2027 CONTINUE - ELSE IF (KPDS(3).EQ.29.OR.KPDS(3).EQ.30)THEN -C ----- U.S. GRIDS 29,30 - MAP SIZE 5365 - J = 5365 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2029 I = 1, J - KBMS(I) = .TRUE. - 2029 CONTINUE - ELSE IF (KPDS(3).EQ.33.OR.KPDS(3).EQ.34) THEN -C ----- U.S GRID 33, 34 - MAP SIZE 8326 (181 X 46) - J = 8326 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2033 I = 1, J - KBMS(I) = .TRUE. - 2033 CONTINUE - ELSE IF (KPDS(3).EQ.50) THEN -C ----- U.S. GRID 50 - MAP SIZE 964 - J = 1188 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2050 I = 1, 1188 - KBMS(I) = GRD50(I) - 2050 CONTINUE - ELSE IF (KPDS(3).EQ.61.OR.KPDS(3).EQ.62) THEN -C ----- U.S. GRIDS 61, 62 - MAP SIZE 4186 - J = 4186 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2061 I = 1, 4186 - KBMS(I) = GRD61(I) - 2061 CONTINUE - ELSE IF (KPDS(3).EQ.63.OR.KPDS(3).EQ.64) THEN -C ----- U.S. GRIDS 63, 64 - MAP SIZE 4186 - J = 4186 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2063 I = 1, 4186 - KBMS(I) = GRD63(I) - 2063 CONTINUE - ELSE IF (KPDS(3).EQ.70) THEN -C ----- U.S. GRID 70 - MAP SIZE 16380 - J = 16380 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2070 I = 1, J - KBMS(I) = .TRUE. - 2070 CONTINUE - ELSE IF (KPDS(3).EQ.85.OR.KPDS(3).EQ.86) THEN -C ----- U.S. GRIDS 85, 86 - MAP SIZE 32400 (360 X 90) - J = 32400 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2085 I = 1, J - KBMS(I) = .TRUE. - 2085 CONTINUE - ELSE IF (KPDS(3).EQ.100) THEN -C ----- U.S. GRID 100 - MAP SIZE 6889 (83 X 83) - J = 6889 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 1100 I = 1, J - KBMS(I) = .TRUE. - 1100 CONTINUE - ELSE IF (KPDS(3).EQ.101) THEN -C ----- U.S. GRID 101 - MAP SIZE 10283 (113 X 91) - J = 10283 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2101 I = 1, J - KBMS(I) = .TRUE. - 2101 CONTINUE - ELSE IF (KPDS(3).EQ.102) THEN -C ----- U.S. GRID 102 - MAP SIZE 14375 (115 X 125) - J = 14375 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2102 I = 1, J - KBMS(I) = .TRUE. - 2102 CONTINUE - ELSE IF (KPDS(3).EQ.103) THEN -C ----- U.S. GRID 103 - MAP SIZE 3640 (65 X 56) - J = 3640 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2103 I = 1, J - KBMS(I) = .TRUE. - 2103 CONTINUE - ELSE IF (KPDS(3).GE.201.AND.KPDS(3).LE.214) THEN - IF (KPDS(3).EQ.201) J = 4225 - IF (KPDS(3).EQ.202) J = 2795 - IF (KPDS(3).EQ.203) J = 1755 - IF (KPDS(3).EQ.204) J = 5609 - IF (KPDS(3).EQ.205) J = 1755 - IF (KPDS(3).EQ.206) J = 2091 - IF (KPDS(3).EQ.207) J = 1715 - IF (KPDS(3).EQ.208) J = 625 - IF (KPDS(3).EQ.209) J = 8181 - IF (KPDS(3).EQ.210) J = 625 - IF (KPDS(3).EQ.211) J = 2915 - IF (KPDS(3).EQ.212) J = 4225 - IF (KPDS(3).EQ.213) J = 10965 - IF (KPDS(3).EQ.214) J = 6693 - KPTR(10) = J - CALL AI087(*900,J,KPDS,KGDS,KRET) - DO 2201 I = 1, J - KBMS(I) = .TRUE. - 2201 CONTINUE - ELSE - KRET = 5 - RETURN - END IF - ELSE - KRET = 10 - RETURN - END IF - 900 CONTINUE - RETURN - END - SUBROUTINE AI085(MSGA,KPTR,KPDS,KBMS,DATA,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AI085 EXTRACT GRIB DATA ELEMENTS -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 88-01-20 -C -C ABSTRACT: EXTRACT GRIB DATA AND PLACE INTO OUTPUT ARRY IN -C PROPER POSITION. -C -C PROGRAM HISTORY LOG: -C 88-01-20 CAVANAUGH -C 90-09-01 R.E.JONES CHANGE'S FOR ANSI FORTRAN -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C 90-12-05 R.E.JONES CHANGE'S FOR GRIB NOV. 21,1990 -C -C USAGE: CALL AI085(MSGA,KPTR,KPDS,KBMS,DATA,KRET) -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS -C (4) - LENGTH OF GDS -C (5) - LENGTH OF BMS -C (6) - LENGTH OF BDS -C (7) - VALUE OF CURRENT BYTE -C (8) - UNUSED -C (9) - GRIB START BYTE NR -C (10) - GRIB/GRID ELEMENT COUNT -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR OF CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C KBMS - BITMAP DESCRIBING LOCATION OF OUTPUT ELEMENTS. -C -C OUTPUT ARGUMENT LIST: -C DATA - REAL ARRAY OF GRIDDED ELEMENTS IN GRIB MESSAGE. -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C ERROR RETURN -C 3 = UNPACKED FIELD IS LARGER THAN 32768 -C 6 = DOES NOT MATCH NR OF ENTRIES FOR THIS GRIB/GRID -C 7 = NUMBER OF BITS IN FILL TOO LARGE -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C ************************************************************* - CHARACTER*1 MSGA(*) - CHARACTER*1 KREF(8) - CHARACTER*1 KK(8) -C - LOGICAL KBMS(*) -C - INTEGER KPDS(*) - INTEGER KPTR(*) - INTEGER NRBITS - INTEGER KSAVE(105000) - INTEGER KSCALE -C - REAL DATA(*) - REAL REFNCE - REAL SCALE - REAL REALKK -C - LOGICAL IBM370 -C - EQUIVALENCE (REFNCE,KREF(1),IREF) - EQUIVALENCE (KK(1),REALKK,IKK) -C -C DATA MSK0F /Z0000000F/ -C DATA MSK80 /Z00000080/ -C DATA MSK40 /Z00000040/ -C - DATA MSK0F /15/ - DATA MSK80 /128/ - DATA MSK40 /64/ -C -C ************************************************************* - KRET = 0 - IS = KPTR(9) - ISS = IS + KPTR(3) + KPTR(4) + KPTR(5) + 4 -C BYTE 4 - KSPL = MOVA2I(MSGA(ISS+3)) -C POINT TO BYTE 5 OF BDS -C -C ------------- GET SCALE FACTOR -C - KSCALE = 0 - DO 100 I = 0, 1 - KSCALE = KSCALE * 256 + MOVA2I(MSGA(I+ISS+4)) - 100 CONTINUE - IF (IAND(KSCALE,32768).NE.0) THEN - KSCALE = - IAND(KSCALE,32767) - END IF - SCALE = 2.0**KSCALE -C -C ------------ GET REFERENCE VALUE -C - IREF = 0 - DO 200 I = 0, 3 - KREF(I+1) = MSGA(I+ISS+6) - 200 CONTINUE -C -C THE FLOATING POINT NUMBER IN THE REFERENCE VALUE IS AN IBM370 -C 32 BIT NUMBER, IF YOUR COMPUTER IS NOT AN IBM370 OR CLONE -C SET IBM370 TO .FALSE. SO THE NUMBER IS CONVERTED TO A F.P. -C NUMBER OF YOUR MACHINE TYPE. -C - IBM370 = .FALSE. -C - IF (.NOT.IBM370) THEN - KOFF = 0 -C GET 1 BIT SIGN - CALL GBYTE(IREF,ISGN,0,1) -C GET 7 BIT EXPONENT - CALL GBYTE(IREF,IEXP,1,7) -C GET 24 BIT FRACTION - CALL GBYTE(IREF,IFR,8,24) - IF (IFR.EQ.0.OR.IEXP.EQ.0) THEN - REFNCE = 0.0 - ELSE - REFNCE = FLOAT(IFR) * 16.0 ** (IEXP-64-6) - IF (ISGN.NE.0) REFNCE = - REFNCE - ENDIF - ENDIF -C -C ------------- NUMBER OF BITS SPECIFIED FOR EACH ENTRY -C - KBITS = MOVA2I(MSGA(ISS+10)) - KENTRY = KPTR(10) -C -C ------------- MAX SIZE CHECK -C - IF (KENTRY.GT.105000) THEN - KRET = 3 - RETURN - END IF - IF (KBITS.EQ.0) THEN -C -C -------------------- HAVE NO BDS ENTRIES, ALL ENTRIES = REFNCE -C - DO 210 I = 1, KENTRY - DATA(I) = 0.0 - IF (KBMS(I)) THEN - DATA(I) = REFNCE - END IF - 210 CONTINUE - GO TO 900 - END IF -C -C -------------------- -C CYCLE THRU BDS UNTIL HAVE USED ALL (SPECIFIED NUMBER) -C ENTRIES. -C -C ------------- UNUSED BITS IN DATA AREA -C - LESSBT = IAND(KSPL,MSK0F) -C -C ------------- NUMBER OF BYTES IN DATA AREA -C - NRBYTE = KPTR(6) - 11 -C -C ------------- TOTAL NR OF USABLE BITS -C - NRBITS = NRBYTE * 8 - LESSBT -C -C ------------- TOTAL NR OF ENTRIES -C - KENTRY = NRBITS / KBITS -C -C ------------- MAX SIZE CHECK -C - IF (KENTRY.GT.105000) THEN - KRET = 3 - RETURN - END IF -C - IBMS = IAND(KPDS(4),MSK40) -C -C -------------- CHECK TO SEE IF PROCESSING COEFFICIENTS -C IF YES, -C GO AND PROCESS AS SUCH -C ELSE -C CONTINUE PROCESSING -C - IF (IAND(KSPL,MSK80).EQ.0) THEN -C -C ------------- SET POINTERS -C -C XMOVEX MOVES THE DATA TO MAKE SURE IT IS ON A INTEGER WORD -C BOUNDARY, ON SOME COMPUTERS THIS DOES NOT HAVE TO BE DONE. -C (IBM PC, VAX) -C -C CALL XMOVEX(MSGB,MSGA(ISS+11),NRBYTE) -C ------------- UNPACK ALL FIELDS - KOFF = 0 -C -C THE BIT UNPACKER W3AI41 WILL CONSUME MOST OF THE CPU TIME -C CONVERTING THE GRIB DATA. FOR THE IBM370 WE HAVE AN -C ASSEMBLER AND FORTRAN VERSION. THE ASSMBLER VERSION WILL -C RUN TWO TO THREE TIMES FASTER. THE FORTRAN VERSION IS TO -C MAKE THE CODE MORE PORTABLE. FOR A VAX OR IBM PC WE HAVE -C ANOTHER VERSION, IT REVERSED THE ORDER OF THE BYTES IN -C AN INTEGER WORD. W3AI41 CAN BE REPLACED BY NCAR GBYTES -C BIT UNPACKER. NCAR HAS A LARGE NUMBER OF VERSIONS OF GBYTES -C IN FORTRAN AN ASSEMBLER FOR A NUMBER OF DIFFERENT BRANDS OF -C COMPUTERS. THEY ALSO HAVE A C VERSION. -C -C CALL W3AI41(MSGB,KSAVE,KBITS,KENTRY,KOFF) -C -C ALIGN CHARACTER ARRAY MSGA STARTING ADDRESS ON CRAY -C INTEGER WORD BOUNDARY -C - LLL = MOD(ISS+10,8) - NNN = 11 - LLL - KOFF = LLL * 8 - CALL GBYTES(MSGA(ISS+NNN),KSAVE,KOFF,KBITS,0,KENTRY) -C -C ------------- CORRECTLY PLACE ALL ENTRIES -C - II = 1 - KENTRY = KPTR(10) - DO 500 I = 1, KENTRY - IF (KBMS(I)) THEN - DATA(I) = REFNCE + FLOAT(KSAVE(II)) * SCALE - II = II + 1 - ELSE - DATA(I) = 0.0 - END IF - 500 CONTINUE - GO TO 900 - END IF -C -C ------------- PROCESS SPHERICAL HARMONIC COEFFICIENTS -C - IKK = 0 - DO 5500 I = 0, 3 - KK(I+1) = MSGA(I+ISS+11) - 5500 CONTINUE -C - IF (.NOT.IBM370) THEN - KOFF = 0 -C GET 1 BIT SIGN - CALL GBYTE(IKK,ISGN,0,1) -C GET 7 BIT EXPONENT - CALL GBYTE(IKK,IEXP,1,7) -C GET 24 BIT FRACTION - CALL GBYTE(IKK,IFR,8,24) - IF (IFR.EQ.0.OR.IEXP.EQ.0) THEN - REALKK = 0.0 - ELSE - REALKK = FLOAT(IFR) * 16.0 ** (IEXP-64-6) - IF (ISGN.NE.0) REALKK = - REALKK - ENDIF - ENDIF -C - DATA(1) = REALKK - KOFF = 0 -C CALL XMOVEX(MSGB,MSGA(ISS+15),NRBYTE) -C ------------- UNPACK ALL FIELDS -C -C CALL W3AI41(MSGB,KSAVE,KBITS,KENTRY,KOFF) -C -C ALIGN CHARACTER ARRAY MSGA STARTING ADDRESS ON CRAY -C INTEGER WORD BOUNDARY -C - LLL = MOD(ISS+14,8) - NNN = 15 - LLL - KOFF = LLL * 8 -C - CALL GBYTES(MSGA(ISS+NNN),KSAVE,KOFF,KBITS,0,KENTRY) -C -C -------------- - DO 6000 I = 1, KENTRY - DATA(I+1) = REFNCE + FLOAT(KSAVE(I)) * SCALE - 6000 CONTINUE - 900 CONTINUE - RETURN - END - SUBROUTINE AI085A(MSGA,KPTR,KPDS,KBMS,DATA,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AI085A EXTRACT GRIB DATA (VER 1) ELEMENTS -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 89-11-20 -C -C ABSTRACT: EXTRACT GRIB DATA (VERSION 1) AND PLACE INTO PROPER -C POSITION IN OUTPUT ARRAY. -C -C PROGRAM HISTORY LOG: -C 89-11-20 CAVANAUGH -C 90-09-01 R.E.JONES CHANGE'S FOR ANSI FORTRAN -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C 90-12-05 R.E.JONES CHANGE'S FOR GRIB NOV. 21,1990 -C -C USAGE: CALL AI085A (MSGA,KPTR,KPDS,KBMS,DATA,KRET) -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS -C (4) - LENGTH OF GDS -C (5) - LENGTH OF BMS -C (6) - LENGTH OF BDS -C (7) - VALUE OF CURRENT BYTE -C (8) - UNUSED -C (9) - GRIB START BYTE NR -C (10) - GRIB/GRID ELEMENT COUNT -C KPDS - ARRAY CONTAINING PDS ELEMENTS. (VERSION 1) -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - TOTAL LENGTH OF GRIB MESSAGE (INCLUDING SECTION 0) -C KBMS - BITMAP DESCRIBING LOCATION OF OUTPUT ELEMENTS. -C -C OUTPUT ARGUMENT LIST: -C DATA - REAL ARRAY OF GRIDDED ELEMENTS IN GRIB MESSAGE. -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C STRUCTURE OF BINARY DATA SECTION (VERSION 1) -C 1-3 - LENGTH OF SECTION -C 4 - PACKING FLAGS -C 5-6 - SCALE FACTOR -C 7-10 - REFERENCE VALUE -C 11 - NUMBER OF BIT FOR EACH VALUE -C 12-N - DATA -C ERROR RETURN -C 3 = UNPACKED FIELD IS LARGER THAN 32768 -C 6 = DOES NOT MATCH NR OF ENTRIES FOR THIS GRIB/GRID -C 7 = NUMBER OF BITS IN FILL TOO LARGE -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C ************************************************************* - CHARACTER*1 MSGA(*) - CHARACTER*1 KREF(8) - CHARACTER*1 KK(8) -C - LOGICAL KBMS(*) -C - INTEGER KPDS(*) - INTEGER KPTR(*) - INTEGER NRBITS - INTEGER KSAVE(105000) - INTEGER KSCALE -C - REAL DATA(*) - REAL REFNCE - REAL SCALE - REAL REALKK -C - LOGICAL IBM370 -C - EQUIVALENCE (REFNCE,KREF(1),IREF) - EQUIVALENCE (KK(1),REALKK,IKK) -C -C DATA MSK0F /Z0000000F/ -C DATA MSK40 /Z00000040/ -C DATA MSK80 /Z00000080/ -C - DATA MSK0F /15/ - DATA MSK40 /64/ - DATA MSK80 /128/ -C -C ************************************************************* -C - KRET = 0 - IS = KPTR(9) - IGRIBL = 8 - ISS = IS + KPTR(3) + KPTR(4) + KPTR(5) + IGRIBL -C BYTE 4 - KSPL = MOVA2I(MSGA(ISS+3)) -C -C ------------- POINT TO BYTE 5 OF BDS -C -C ------------- GET SCALE FACTOR -C - KSCALE = 0 - DO 100 I = 0, 1 - KSCALE = KSCALE * 256 + MOVA2I(MSGA(I+ISS+4)) - 100 CONTINUE - IF (IAND(KSCALE,32768).NE.0) THEN - KSCALE = - IAND(KSCALE,32767) - END IF - SCALE = 2.0**KSCALE -C -C -------------------- DECIMAL SCALE EXPONENT -C - IDEC = IS + IGRIBL + 26 - JSCALE = 0 - DO 150 I = 0, 1 - JSCALE = JSCALE * 256 + MOVA2I(MSGA(I+IDEC)) - 150 CONTINUE -C IF HIGH ORDER BIT IS ON, HAVE NEGATIVE EXPONENT - IF (IAND(JSCALE,32768).NE.0) THEN - JSCALE = - IAND(JSCALE,32767) - END IF - ASCALE = 10.0 ** JSCALE -C -C ------------ GET REFERENCE VALUE -C - IREF = 0 - DO 200 I = 0, 3 - KREF(I+1) = MSGA(I+ISS+6) - 200 CONTINUE -C -C THE FLOATING POINT NUMBER IN THE REFERENCE VALUE IS AN IBM370 -C 32 BIT NUMBER, IF YOUR COMPUTER IS NOT AN IBM370 OR CLONE -C SET IBM370 TO .FALSE. SO THE NUMBER IS CONVERTED TO A F.P. -C NUMBER OF YOUR MACHINE TYPE. -C - IBM370 = .FALSE. -C - IF (.NOT.IBM370) THEN - KOFF = 0 -C GET 1 BIT SIGN - CALL GBYTE(IREF,ISGN,0,1) -C GET 7 BIT EXPONENT - CALL GBYTE(IREF,IEXP,1,7) -C GET 24 BIT FRACTION - CALL GBYTE(IREF,IFR,8,24) - IF (IFR.EQ.0.OR.IEXP.EQ.0) THEN - REFNCE = 0.0 - ELSE - REFNCE = FLOAT(IFR) * 16.0 ** (IEXP-64-6) - IF (ISGN.NE.0) REFNCE = - REFNCE - ENDIF - ENDIF -C -C ------------- NUMBER OF BITS SPECIFIED FOR EACH ENTRY -C - KBITS = MOVA2I(MSGA(ISS+10)) - KENTRY = KPTR(10) -C -C ------------- MAX SIZE CHECK -C - IF (KENTRY.GT.105000) THEN - KRET = 3 - RETURN - END IF -C - IF (KBITS.EQ.0) THEN -C -C -------------------- HAVE NO BDS ENTRIES, ALL ENTRIES = REFNCE -C - DO 210 I = 1, KENTRY - DATA(I) = 0.0 - IF (KBMS(I)) THEN - DATA(I) = REFNCE - END IF - 210 CONTINUE - GO TO 900 - END IF -C -C -------------------- -C CYCLE THRU BDS UNTIL HAVE USED ALL (SPECIFIED NUMBER) -C ENTRIES. -C -C ------------- UNUSED BITS IN DATA AREA -C - LESSBT = IAND(KSPL,MSK0F) -C -C ------------- NUMBER OF BYTES IN DATA AREA -C - NRBYTE = KPTR(6) - 11 -C -C ------------- TOTAL NR OF USABLE BITS -C - NRBITS = NRBYTE * 8 - LESSBT -C -C ------------- TOTAL NR OF ENTRIES -C - KENTRY = NRBITS / KBITS -C -C ------------- MAX SIZE CHECK -C - IF (KENTRY.GT.105000) THEN - KRET = 3 - RETURN - END IF - IBMS = IAND(KPDS(4),MSK40) -C -C -------------- CHECK TO SEE IF PROCESSING COEFFICIENTS -C IF YES, -C GO AND PROCESS AS SUCH -C ELSE -C CONTINUE PROCESSING - IF (IAND(KSPL,MSK80).EQ.0) THEN -C -C ------------- SET POINTERS -C -C REPLACE XMOVEX AND W3AI41 WITH GBYTES -C CALL XMOVEX(MSGB,MSGA(ISS+11),NRBYTE) -C -C ------------- UNPACK ALL FIELDS -C - KOFF = 0 -C CALL W3AI41(MSGB,KSAVE,KBITS,KENTRY,KOFF) -C -C THE BIT UNPACKER W3AI41 WILL CONSUME MOST OF THE CPU TIME -C CONVERTING THE GRIB DATA. FOR THE IBM370 WE HAVE AN -C ASSEMBLER AND FORTRAN VERSION. THE ASSMBLER VERSION WILL -C RUN TWO TO THREE TIMES FASTER. THE FORTRAN VERSION IS TO -C MAKE THE CODE MORE PORTABLE. FOR A VAX OR IBM PC WE HAVE -C ANOTHER VERSION, IT REVERSED THE ORDER OF THE BYTES IN -C AN INTEGER WORD. W3AI41 CAN BE REPLACED BY NCAR GBYTES -C BIT UNPACKER. NCAR HAS A LARGE NUMBER OF VERSIONS OF GBYTES -C IN FORTRAN AND ASSEMBLER FOR A NUMBER OF DIFFERENT BRANDS OF -C COMPUTERS. THEY ALSO HAVE A C VERSION. -C -C ALIGN CHARACTER ARRAY MSGA STARTING ADDRESS ON CRAY -C INTEGER WORD BOUNDARY -C - LLL = MOD(ISS+10,8) - NNN = 11 - LLL - KOFF = LLL * 8 -C - CALL GBYTES(MSGA(ISS+NNN),KSAVE,KOFF,KBITS,0,KENTRY) -C -C ------------- CORRECTLY PLACE ALL ENTRIES -C - II = 1 - KENTRY = KPTR(10) - DO 500 I = 1, KENTRY - IF (KBMS(I)) THEN -C MUST INCLUDE DECIMAL SCALE - DATA(I) = (REFNCE + FLOAT(KSAVE(II)) * SCALE) / ASCALE - II = II + 1 - ELSE - DATA(I) = 0.0 - END IF - 500 CONTINUE - GO TO 900 - END IF -C -C ------------- PROCESS SPHERICAL HARMONIC COEFFICIENTS -C - IKK = 0 - DO 5500 I = 0, 3 - KK(I+1) = MSGA(I+ISS+11) - 5500 CONTINUE -C - IF (.NOT.IBM370) THEN - KOFF = 0 -C GET 1 BIT SIGN - CALL GBYTE(IKK,ISGN,0,1) -C GET 7 BIT EXPONENT - CALL GBYTE(IKK,IEXP,1,7) -C GET 24 BIT FRACTION - CALL GBYTE(IKK,IFR,8,24) - IF (IFR.EQ.0.OR.IEXP.EQ.0) THEN - REALKK = 0.0 - ELSE - REALKK = FLOAT(IFR) * 16.0 ** (IEXP-64-6) - IF (ISGN.NE.0) REALKK = - REALKK - ENDIF - ENDIF -C - DATA(1) = REALKK - KOFF = 0 -C CALL XMOVEX(MSGB,MSGA(ISS+15),NRBYTE) -C -C ------------- UNPACK ALL FIELDS -C -C CALL W3AI41(MSGB,KSAVE,KBITS,KENTRY,KOFF) -C -------------- -C -C ALIGN CHARACTER ARRAY MSGA STARTING ADDRESS ON CRAY -C INTEGER WORD BOUNDARY -C - LLL = MOD(ISS+14,8) - NNN = 15 - LLL - KOFF = LLL * 8 -C - CALL GBYTES(MSGA(ISS+NNN),KSAVE,KOFF,KBITS,0,KENTRY) -C - DO 6000 I = 1, KENTRY - DATA(I+1) = REFNCE + FLOAT(KSAVE(I)) * SCALE - 6000 CONTINUE - 900 CONTINUE - RETURN - END - SUBROUTINE AI087(*,J,KPDS,KGDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: AI087 GRIB GRID/SIZE TEST -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 88-02-08 -C -C ABSTRACT: TO TEST WHEN GDS IS AVAILABLE TO SEE IF SIZE MISMATCH -C ON EXISTING GRIDS (BY CENTER) IS INDICATED -C -C PROGRAM HISTORY LOG: -C 88-02-08 CAVANAUGH -C 90-09-23 R.E.JONES CHANGE'S FOR CRAY CFT77 FORTRAN -C 90-12-05 R.E.JONES CHANGE'S FOR GRIB NOV. 21,1990 -C -C USAGE: CALL AI087(*,J,KPDS,KGDS,KRET) -C INPUT ARGUMENT LIST: -C J - SIZE FOR INDICATED GRID -C KPDS - -C KGDS - -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KRET - ERROR RETURN -C -C REMARKS: -C KRET - -C = 9 - GDS INDICATES SIZE MISMATCH WITH STD GRID -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ - INTEGER KPDS(20) - INTEGER KGDS(13) - INTEGER J - INTEGER I -C --------------------------------------- -C --------------------------------------- -C IF GDS NOT INDICATED, RETURN -C ---------------------------------------- - IF (IAND(KPDS(4),128).EQ.0) RETURN -C --------------------------------------- -C GDS IS INDICATED, PROCEED WITH TESTING -C --------------------------------------- - I = KGDS(2) * KGDS(3) -C --------------------------------------- -C TEST ECMWF CONTENT -C --------------------------------------- - IF (KPDS(1).EQ.98) THEN - KRET = 9 - IF (KPDS(3).GE.1.AND.KPDS(3).LE.16) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE - KRET = 5 - RETURN 1 - END IF -C --------------------------------------- -C U.K. MET OFFICE, BRACKNELL -C --------------------------------------- - ELSE IF (KPDS(1).EQ.74) THEN - KRET = 9 - IF (KPDS(3).GE.21.AND.KPDS(3).LE.24) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.25.OR.KPDS(3).EQ.26) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.70) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE - KRET = 5 - RETURN 1 - END IF -C --------------------------------------- -C NAVY - FNOC -C --------------------------------------- - ELSE IF (KPDS(1).EQ.58) THEN - PRINT *,' NO CURRENT LISTING OF NAVY GRIDS' - RETURN 1 -C --------------------------------------- -C U.S. GRIDS -C --------------------------------------- - ELSE IF (KPDS(1).EQ.7) THEN - KRET = 9 - IF (KPDS(3).EQ.5) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.6) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).GE.21.AND.KPDS(3).LE.24) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.25.OR.KPDS(3).EQ.26) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.27.OR.KPDS(3).EQ.28) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.29.OR.KPDS(3).EQ.30) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.33.OR.KPDS(3).EQ.34) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.50) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.70) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.85.OR.KPDS(3).EQ.86) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.100) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.101) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.102) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).EQ.103) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE IF (KPDS(3).GE.201.AND.KPDS(3).LE.214) THEN - IF (I.NE.J) THEN - RETURN 1 - END IF - ELSE - KRET = 5 - RETURN 1 - END IF - ELSE - KRET = 10 - RETURN 1 - END IF -C ------------------------------------ -C NORMAL EXIT -C ------------------------------------ - KRET = 0 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3ai15.f b/external/w3nco/v2.0.6/src/w3ai15.f deleted file mode 100644 index 6e93f4eac..000000000 --- a/external/w3nco/v2.0.6/src/w3ai15.f +++ /dev/null @@ -1,132 +0,0 @@ - SUBROUTINE W3AI15 (NBUFA,NBUFB,N1,N2,MINUS) -C$$$ SUBROUTINE DOCUMENTATION BLOCK CCC -C -C SUBR: W3AI15 - CONVERT INTEGERS TO ACSII (ALTERNATE TO ENCODE) -C AUTHOR: ALLARD, R. ORG: W342 DATE: JANUARY, 1974 -C -C ABSTRACT: CONVERTS A SET OF BINARY NUMBERS TO AN EQUIVALENT SET -C OF ASCII NUMBER FIELDS IN CORE. THIS IS AN ALTERNATE PROCEDURE -C TO THE USE OF THE 360/195 VERSION OF ENCODE. -C -C PROGRAM HISTORY LOG: -C 74-01-15 R.ALLARD -C 89-02-06 R.E.JONES CHANGE FROM ASSEMBLER TO FORTRAN -C THIS SUBROUTINE SHOULD BE REWRITTEN IM -C INTEL 8088 ASSEMBLY LANGUAGE -C 90-08-13 R.E.JONES CHANGE TO CRAY CFT77 FORTRAN -C 12-11-05 B. VUONG CHANGE VARIABLE ZERO FILL FOR LITTLE-ENDIAN -C -C USAGE: CALL W3AI15 (NBUFA,NBUFB,N1,N2,MINUS) -C -C INPUT: -C 'NBUFA' - INPUT ARRAY (INTEGER*4) -C ' N1' - NUMBER OF INTEGERS IN NBUFA TO BE CONVERTED -C ' N2' - DESIRED CHARACTER WIDTH OF ASCII NUMBER FIELD -C 'MINUS' - CHARACTER TO BE INSERTED IN THE HIGH ORDER POSITION -C OF A NEGATIVE NUMBER FIELD -C OUTPUT: -C 'NBUFB' - OUTPUT ARRAY (INTEGER*4) -C -C EXIT STATES: NONE -C -C EXTERNAL REFERENCES: NONE -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C -C NOTE 1. - IF N2 IS GREATER THAN 4, ALLOW TWO WORDS (EIGHT CHARACTERS) -C IN THE NBUFB ARRAY FOR EACH ASCII NUMBER FIELD. A NUMBER FIELD -C IS LEFT ADJUSTED WITH BLANK FILL TO THE RIGHT IF NEEDED. -C LIKEWISE, IF N2 IS LESS THAN 4, THE RESULT IS LEFT ADJUSTED -C WITH BLANK FILL TO THE RIGHT. -C -C NOTE 2. - N2 CAN BE SPECIFIED IN THE RANGE 1-8. AN EIGHT DIGIT POSI- -C TIVE INTEGER CAN BE CONVERTED OR A SEVEN DIGIT NEGATIVE INTEGER -C AND A SIGN. ZERO FILL IS USED FOR HIGH ORDER POSITIONS IN A -C NUMBER FIELD. THE USER SHOULD BE AWARE THAT W3AI15 DOES NOT -C VERIFY THAT THE VALUE OF N2 IS IN THE CORRECT RANGE. -C -C NOTE 3. - THE MINUS SIGN CAN BE INSERTED AS A LITERAL IN THE CALL -C SEQUENCE OR DEFINED IN A DATA STATEMENT. 1H- AND 1H+ ARE THE -C TWO MOST LIKELY NEGATIVE SIGNS. UNFORTUNATELY THE ASCII PLUS -C CHARACTER IS THE NEGATIVE SIGN REQUIRED IN MOST TRANSMISSIONS. -C THE MINUS SIGN WILL ALWAYS BE IN THE HIGH ORDER POSITION OF A -C NEGATIVE NUMBER FIELD. -C -C NOTE 4. - IF A NUMBER CONTAINS MORE DIGITS THAN THE N2 SPECIFICATION -C ALLOWS, THE EXCESS HIGH ORDER DIGITS ARE LOST. -C - INTEGER ATEMP - INTEGER BTEMP - INTEGER IDIV(8) - INTEGER NBUFA(*) - INTEGER NBUFB(*) - INTEGER*8 ZERO(8) -C - CHARACTER*1 BLANK - CHARACTER*1 JTEMP(8) - CHARACTER*1 MINUS - CHARACTER*1 NUM(0:9) -C - LOGICAL ISIGN -C - EQUIVALENCE (BTEMP,JTEMP(1)) -C - DATA BLANK /' '/ - DATA IDIV /1,10,100,1000,10000,100000,1000000,10000000/ - DATA NUM /'0','1','2','3','4','5','6','7','8','9'/ -C FOR LITTLE_ENDIAN - DATA ZERO /X'2020202020202030',X'2020202020203030', - & X'2020202020303030',X'2020202030303030', - & X'2020203030303030',X'2020303030303030', - & X'2030303030303030',X'3030303030303030'/ - -C FOR BIG_ENDIAN -c DATA ZERO /X'3020202020202020',X'3030202020202020', -c & X'3030302020202020',X'3030303020202020', -c & X'3030303030202020',X'3030303030302020', -c & X'3030303030303020',X'3030303030303030'/ -C - DO 100 I = 1,N1 - IF (NBUFA(I).EQ.0) THEN - NBUFB(I) = ZERO(N2) - GO TO 100 - ENDIF - ATEMP = NBUFA(I) - ISIGN = .FALSE. - IF (ATEMP.LT.0) THEN - ISIGN = .TRUE. - ATEMP = IABS(ATEMP) - ENDIF - IF (.NOT.ISIGN) THEN - DO 10 J = 1,8 - IF (J.LE.N2) THEN - I1 = MOD(ATEMP/IDIV(N2-J+1),10) - JTEMP(J) = NUM(I1) - ELSE - JTEMP(J) = BLANK - ENDIF - 10 CONTINUE - - ELSE - - JTEMP(1) = MINUS - DO 20 J = 2,8 - IF (J.LE.N2) THEN - I1 = MOD(ATEMP/IDIV(N2-J+1),10) - JTEMP(J) = NUM(I1) - ELSE - JTEMP(J) = BLANK - ENDIF - 20 CONTINUE - ENDIF -C - NBUFB(I) = BTEMP -C - 100 CONTINUE - RETURN - END - diff --git a/external/w3nco/v2.0.6/src/w3ai18.f b/external/w3nco/v2.0.6/src/w3ai18.f deleted file mode 100644 index 178c9c6f3..000000000 --- a/external/w3nco/v2.0.6/src/w3ai18.f +++ /dev/null @@ -1,113 +0,0 @@ - SUBROUTINE W3AI18(ITEM,I1,I2,LINE,L,K,N) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3AI18 LINE BUILDER SUBROUTINE -C PRGMMR: ALLARD, R. ORG: W/NMC42 DATE: 74-02-01 -C -C ABSTRACT: BUILD A LINE OF INFORMATION COMPOSED OF USER SPECIFIED -C CHARACTER STRINGS. -C -C PROGRAM HISTORY LOG: -C 74-02-02 ROBERT ALLARD -C 84-07-05 R.E.JONES RECOMPILE -C 96-08-06 R.E.JONES CONVERT FROM IBM370 ASSEMBLER TO FORTRAN -C FOR THE CRAY, WORKSTATIONS, AND PC'S. -C -C USAGE: CALL W3AI18(ITEM, I1, I2, LINE, L, K, N) -C INPUT ARGUMENT LIST: -C ITEM - CHARACTER STRING TO BE ADDED TO LINE ARRAY -C I1 - NUMBER OF CHARACTER STRINGS TO BE ADDED TO LINE ARRAY -C I2 - NUMBER OF CHARACTERS PER STRING TO ADD TO LINE -C L - CHARACTER LENGTH OF LINE TO BE BUILT (2.LE.L.LE.256) -C K - NUMBER OF BLKANK CHARACTERS TO PRECEDE A CHARACTER -C STRING (0.LE.K.LE.256) -C N - POINTER SET EQUAL TO 0 WHEN BEGINNING A LINE -C -C OUTPUT ARGUMENT LIST: -C LINE - ARRAY IN WHICH CHARACTER STRING ARE PLACED WHILE -C BUILDING ALINE; MUST BE OF TYPE INTEGER -C N - CHARACTER COUNT, ERROR INDICATOR -C -C -C EXIT STATES: -C N = -1 CHARACTER STRING WILL NOT FIT IN THE LINE ARRAY; -C OTHERWISE, EACH TIME A CHACTER STRING IS ADDED -C TO THE LINE, N IS INCREMENTED BY (I2 + K) -C -C NOTE 1. - EACH CHARACTER STRING INCLUDED IN THE ITEM ARRAY MUST -C START ON A FULL WORD BOUNDARY AND BE EQUAL IN LENGTH. -C EACH SUCCESSIVE STRING MUST START ON THE NEST FULLWORD -C BOUNDARY FOLLOWING THE END OF THE PREVIOUS STRING. -C ON A CRAY THIS 8. -C -C NOTE 2. - THE DIMENSIONS OF THE ITEM ARRAY SHOULD BE AT LEAST THE -C VALUE OF (I1*(I2+J))/4, WHERE THE INTEGER J IS IN THE -C RANGE 0.LE.J.LE.3 AND THE SUM (I2+J) IS 4 OR A MULTIPLE -C OF 4. ON A CRAY THIS IS 8 OR A MULTIPLE OF 8. ON A CRAY -C (I1*(I2+J))/8, RANGE IS 0.LE.J.LE.7 -C -C NOTE 3. - THE MAXIMUM DIMENSION OF LINE IS 64 WORD OR 256 BYTES. -C ON A CRAY IT IS 32 WORDS OR 256 BYTES. -C -C NOTE 4. - THE USER SHOULD SET N = 0 EACH TIME A LINE IS STATED TO -C TELL W3AI18 TO FILL THE LINE ARRAY WITH BLANK CHARACTERS. -C EACH TIME A CHARACTER STRING IS ADDED TO THE LINE, THE -C VARIABLE (N) IS INCREMENTED BY (I2 + K). IF A CHARACTER -C STRING WILL NOT FIT IN THE LINE ARRAY, W3AI18 SETS N = -1 -C AND RETURNS TO THE USER. THE USER WILL NOT BE ABLE TO -C PROGRAM A RECOVERY PROCEDURE FOR THE LINE BEING FULL IF -C MORE THAN ONE CHARACTER STRING IS IN THE ITEM ARRAY. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916/256, J916/2048. -C -C$$$ -C - CHARACTER * (*) LINE - CHARACTER * (*) ITEM -C - SAVE -C -C TEST WORD LENGTH, LW WILL BE 4 OR 8 BYTES -C - CALL W3FI01(LW) -C -C BAIL OUT IF NEGATIVE -C - IF (N.LT.0) RETURN -C -C FILL LINE WITH BLANK CHAACTERS -C - IF (N.EQ.0) THEN - DO I = 1,L - LINE(I:I) = ' ' - END DO - END IF - IF (I1.EQ.1) THEN - J = 0 - IF ((I2+K+N).GT.L) GO TO 200 - LINE(K+N+1:K+N+I2) = ITEM(1:I2) - N = I2+K+N - RETURN - ELSE - JJ = MOD(I2, LW) - IF (JJ.EQ.0) THEN - J = 0 - ELSE - J = LW - JJ - END IF - IF ((I2+K+N).GT.L) GO TO 200 - LINE(K+N+1:K+N+I2) = ITEM(1:I2) - N = I2+K+N - DO I = 1,I1-1 - IF ((I2+K+N).GT.L) GO TO 200 - LINE(K+N+1:K+N+I2) = ITEM((I2+J)*I+1:(I2+J)*I+I2) - N = I2+K+N - END DO - RETURN - END IF - 200 CONTINUE - N = -1 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3ai19.f b/external/w3nco/v2.0.6/src/w3ai19.f deleted file mode 100644 index f2654dac6..000000000 --- a/external/w3nco/v2.0.6/src/w3ai19.f +++ /dev/null @@ -1,127 +0,0 @@ - SUBROUTINE W3AI19(LINE, L, NBLK, N, NEXT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3AI19 LINE BLOCKER SUBROUTINE -C PRGMMR: BOB HOLLERN ORG: NCO/NP12 DATE: 97-04-15 -C -C ABSTRACT: FILLS A RECORD BLOCK WITH LOGICAL RECORDS OR LINES -C OF INFORMATION. -C -C PROGRAM HISTORY LOG: -C 74-02-01 BOB ALLARD, AUTHOR -C 90-09-15 R.E.JONES CONVERT FROM IBM370 ASSEMBLER TO MICROSOFT -C FORTRAN 5.0 -C 90-10-07 R.E.JONES CONVERT TO SUN FORTRAN 1.3 -C 91-07-20 R.E.JONES CONVERT TO SiliconGraphics 3.3 FORTRAN 77 -C 93-03-29 R.E.JONES ADD SAVE STATEMENT -C 94-04-22 R.E.JONES ADD XMOVEX AND XSTORE TO MOVE AND -C STORE CHARACTER DATA FASTER ON THE CRAY -C 97-04-15 Bob Hollern CORRECTED THE PROBLEM OF INIIALIZING NBLK -C TO @'S INSTEAD OF BLANKS -C -C USAGE: CALL W3AI19 (LINE, L, NBLK, N, NEXT) -C INPUT ARGUMENT LIST: -C LINE - ARRAY ADDRESS OF LOGICAL RECORD TO BE BLOCKED -C L - NUMBER OF CHARACTERS IN LINE TO BE BLOCKED -C N - MAXIMUM CHARACTER SIZE OF NBLK -C NEXT - FLAG, INITIALIZED TO 0 -C -C OUTPUT ARGUMENT LIST: -C NBLK - BLOCK FILLED WITH LOGICAL RECORDS -C NEXT - CHARACTER COUNT, ERROR INDICATOR -C -C EXIT STATES: -C NEXT = -1 LINE WILL NOT FIT INTO REMAINDER OF BLOCK; -C OTHERWISE, NEXT IS SET TO (NEXT + L) -C NEXT = -2 N IS ZERO OR LESS -C NEXT = -3 L IS ZERO OR LESS -C -C EXTERNAL REFERENCES: XMOVEX XSTORE -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916-128, CRAY Y-MP8/864, CRAY Y-MP EL2/256 -C -C$$$ -C -C METHOD: -C -C THE USER MUST SET NEXT = 0 EACH TIME NBLK IS TO BE FILLED WITH -C LOGICAL RECORDS. -C -C W3AI19 WILL THEN MOVE THE LINE OF INFORMATION INTO NBLK, STORE -C BLANK CHARACTERS IN THE REMAINDER OF THE BLOCK, AND SET NEXT = NEXT -C + L. -C -C EACH TIME W3AI19 IS ENTERED, ONE LINE IS BLOCKED AND NEXT INCRE- -C MENTED UNTIL A LINE WILL NOT FIT THE REMAINDER OF THE BLOCK. THEN -C W3AI19 WILL SET NEXT = -1 AS A FLAG FOR THE USER TO DISPOSE OF THE -C BLOCK. THE USER SHOULD BE AWARE THAT THE LAST LOGICAL RECORD WAS NOT -C BLOCKED. -C - INTEGER L - INTEGER N - INTEGER NEXT - INTEGER(8) WBLANK -C - CHARACTER * 1 LINE(*) - CHARACTER * 1 NBLK(*) - CHARACTER * 1 BLANK -C - SAVE -C - DATA WBLANK/Z'2020202020202020'/ -C -C TEST VALUE OF NEXT. -C - IF (NEXT.LT.0) THEN - RETURN -C -C TEST N FOR ZERO OR LESS -C - ELSE IF (N.LE.0) THEN - NEXT = -2 - RETURN -C -C TEST L FOR ZERO OR LESS -C - ELSE IF (L.LE.0) THEN - NEXT = -3 - RETURN -C -C TEST TO SEE IF LINE WILL FIT IN BLOCK. -C - ELSE IF ((L + NEXT).GT.N) THEN - NEXT = -1 - RETURN -C -C FILL BLOCK WITH BLANK CHARACTERS IF NEXT EQUAL ZERO. -C BLANK IS EBCDIC BLANK, 40 HEX, OR 64 DECIMAL -C - ELSE IF (NEXT.EQ.0) THEN - CALL W3FI01(LW) - IWORDS = N / LW - CALL XSTORE(NBLK,WBLANK,IWORDS) - IF (MOD(N,LW).NE.0) THEN - NWORDS = IWORDS * LW - IBYTES = N - NWORDS - DO I = 1,IBYTES - NBLK(NWORDS+I) = CHAR(32) - END DO - END IF - END IF -C -C MOVE LINE INTO BLOCK. -C -C DO 20 I = 1,L -C NBLK(I + NEXT) = LINE(I) -C20 CONTINUE - CALL XMOVEX(NBLK(NEXT+1),LINE,L) -C -C ADJUST VALUE OF NEXT. -C - NEXT = NEXT + L -C - RETURN -C - END diff --git a/external/w3nco/v2.0.6/src/w3ai24.f b/external/w3nco/v2.0.6/src/w3ai24.f deleted file mode 100644 index bea6da9ff..000000000 --- a/external/w3nco/v2.0.6/src/w3ai24.f +++ /dev/null @@ -1,49 +0,0 @@ - LOGICAL FUNCTION W3AI24(STRING1, STRING2,LENGTH) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C FUNCT W3AI24 TEST FOR MATCH OF TWO STRINGS -C PRGMMR: LUKELIN ORG: NMC421 DATE:94-08-31 -C -C ABSTACT: TEST TWO STRINGS. -C IF ALL EQUAL; OTHERWISE .FALSE. -C -C PROGRAM HISTORY LOG: -C 94-08-31 LUKE LIN -C -C USAGE: II = W3AI24(STRING1,STRING2,LENGTH) -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C STRING1 ARG LIST CHARACTER ARRAY TO MATCH WITH STRING2 -C STRING2 ARG LIST CHARACTER ARRAY TO MATCH WITH STRING1 -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C W3AI24 FUNCTION LOGICAL .TRUE. IF S1 AND S2 MATCH ON ALL CHAR., -C LOGICAL .FALSE. IF NOT MATCH ON ANY CHAR. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN -C MACHINE: NAS -C -C$$$ -C - CHARACTER*1 STRING1(*) - CHARACTER*1 STRING2(*) - INTEGER*4 LENGTH -C - W3AI24 = .TRUE. -C - DO 10 I = 1,LENGTH - IF (STRING1(I).NE.STRING2(I)) GO TO 40 - 10 CONTINUE -C - RETURN -C - 40 CONTINUE - W3AI24 = .FALSE. - RETURN -C - END diff --git a/external/w3nco/v2.0.6/src/w3ai38.f b/external/w3nco/v2.0.6/src/w3ai38.f deleted file mode 100644 index b8e2f1270..000000000 --- a/external/w3nco/v2.0.6/src/w3ai38.f +++ /dev/null @@ -1,84 +0,0 @@ - SUBROUTINE W3AI38 (IE, NC ) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3AI38 EBCDIC TO ASCII -C PRGMMR: DESMARAIS ORG: W342 DATE: 82-11-29 -C -C ABSTRACT: CONVERT EBCDIC TO ASCII BY CHARACTER. -C THIS SUBROUTINE CAN BE REPLACED BY CRAY UTILITY SUBROUTINE -C USCCTC . SEE MANUAL SR-2079 PAGE 3-15. CRAY UTILITY TR -C CAN ALSO BE USED FOR ASCII, EBCDIC CONVERSION. SEE MANUAL SR-2079 -C PAGE 9-35. -C -C PROGRAM HISTORY LOG: -C 82-11-29 DESMARAIS -C 88-03-31 R.E.JONES CHANGE LOGIC SO IT WORKS LIKE A -C IBM370 TRANSLATE INSTRUCTION. -C 88-08-22 R.E.JONES CHANGES FOR MICROSOFT FORTRAN 4.10 -C 88-09-04 R.E.JONES CHANGE TABLES TO 128 CHARACTER SET -C 90-01-31 R.E.JONES CONVERT TO CRAY CFT77 FORTRAN -C CRAY DOES NOT ALLOW CHAR*1 TO BE SET TO HEX -C 98-12-21 Gilbert Replaced Function ICHAR with mova2i. -C -C USAGE: CALL W3AI38 (IE, NC) -C INPUT ARGUMENT LIST: -C IE - CHARACTER*1 ARRAY OF EBCDIC DATA -C NC - INTEGER, CONTAINS CHARACTER COUNT TO CONVERT.... -C -C OUTPUT ARGUMENT LIST: -C IE - CHARACTER*1 ARRAY OF ASCII DATA -C -C REMARKS: SOFTWARE VERSION OF IBM370 TRANSLATE INSTRUCTION, BY -C CHANGING THE TWO TABLES WE COULD DO A 64, 96, 128 ASCII -C CHARACTER SET, CHANGE LOWER CASE TO UPPER, ETC. -C AEA CONVERTS DATA AT A RATE OF 1.5 MILLION CHARACTERS PER SEC. -C CRAY UTILITY USCCTI CONVERT ASCII TO IBM EBCDIC -C CRAY UTILITY USCCTC CONVERT IBM EBCDIC TO ASCII -C THEY CONVERT DATA AT A RATE OF 2.1 MILLION CHARACTERS PER SEC. -C CRAY UTILITY TR WILL ALSO DO A ASCII, EBCDIC CONVERSION. -C TR CONVERT DATA AT A RATE OF 5.4 MILLION CHARACTERS PER SEC. -C TR IS IN LIBRARY /USR/LIB/LIBCOS.A ADD TO SEGLDR CARD. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/864 -C -C$$$ -C - INTEGER(8) IASCII(32) -C - CHARACTER*1 IE(*) - CHARACTER*1 ASCII(0:255) -C - EQUIVALENCE (IASCII(1),ASCII(0)) -C -C*** ASCII CONTAINS ASCII CHARACTERS, AS PUNCHED ON IBM029 -C - DATA IASCII/ - & X'000102030009007F',X'0000000B0C0D0E0F', - & X'1011120000000000',X'1819000000000000', - & X'00001C000A001700',X'0000000000050607', - & X'00001600001E0004',X'000000001415001A', - & X'2000600000000000',X'0000602E3C282B00', - & X'2600000000000000',X'000021242A293B5E', - & X'2D2F000000000000',X'00007C2C255F3E3F', - & X'0000000000000000',X'00603A2340273D22', - & X'2061626364656667',X'6869202020202020', - & X'206A6B6C6D6E6F70',X'7172202020202020', - & X'207E737475767778',X'797A2020205B2020', - & X'0000000000000000',X'00000000005D0000', - & X'7B41424344454647',X'4849202020202020', - & X'7D4A4B4C4D4E4F50',X'5152202020202020', - & X'5C20535455565758',X'595A202020202020', - & X'3031323334353637',X'3839202020202020'/ -C - IF (NC .LE. 0) RETURN -C -C*** CONVERT STRING ... EBCDIC TO ASCII, NC CHARACTERS -C - DO 20 J = 1, NC - IE(J) = ASCII(mova2i(IE(J))) - 20 CONTINUE -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3ai39.f b/external/w3nco/v2.0.6/src/w3ai39.f deleted file mode 100644 index 266bd233d..000000000 --- a/external/w3nco/v2.0.6/src/w3ai39.f +++ /dev/null @@ -1,81 +0,0 @@ - SUBROUTINE W3AI39 (NFLD, N) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3AI39 TRANSLATE 'ASCII' FIELD TO 'EBCDIC' -C PRGMMR: DESMARAIS ORG: W342 DATE: 93-10-06 -C -C ABSTRACT: TRANSLATE AN 'ASCII' FIELD TO 'EBCDIC', ALL ALPHANUMERICS, -C SPECIAL CHARCATERS, FILL SCATTER, BROCKEN< CLEAR, OVERCAST, BELL, -C HT AND VT (FOR AFOS). SPACE, '6D' TO '5E' CONVERSION (HDROLOGY), -C CHANGERS WERE MADE TO W3AI38 TO GIVE REVERSE TABLE TRANSLATION -C -C PROGRAM HISTORY LOG: -C 93-10-06 R.E.JONES CONVERT IBM370 ASSEBLER VERSION TO FORTRAN -C 94-04-28 R.E.JONES CHANGES FOR CRAY -C 98-12-21 Gilbert Replaced Function ICHAR with mova2i. -C -C USAGE: CALL W3AI39 (NFLD,N) -C INPUT ARGUMENT LIST: -C NFLD - CHARACTER*1 ARRAY OF ASCII DATA -C N - INTEGER, CONTAINS CHARACTER COUNT TO CONVERT.... -C -C OUTPUT ARGUMENT LIST: -C NFLD - CHARACTER*1 ARRAY OF EBCDIC DATA -C -C REMARKS: SOFTWARE VERSION OF IBM370 TRANSLATE INSTRUCTION, BY -C CHANGING THE TABLE WE COULD DO A 64, 96, ASCII -C CHARACTER SET, CHANGE LOWER CASE TO UPPER, ETC. -C TR CONVERT DATA AT A RATE OF 5.4 MILLION CHARACTERS PER SEC. -C TR IS IN LIBRARY /USR/LIB/LIBCOS.A ADD TO SEGLDR CARD. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/864 -C -C$$$ -C - INTEGER(8) IEBCDC(32) -C - CHARACTER*1 NFLD(*) - CHARACTER*1 EBCDIC(0:255) -C - SAVE -C - EQUIVALENCE (IEBCDC(1),EBCDIC(0)) -C -C*** EBCDIC CONTAINS HEX. REPRESENTATION OF EBCDIC CHARACTERS -C -C DATA IEBCDC/ -C & X'00010203372D2E2F',X'1605250B0C0D0E0F', -C & X'101112003C3D3226',X'18193F2722003500', -C & X'405A7F7B5B6C507D',X'4D5D5C4E6B604B61', -C & X'F0F1F2F3F4F5F6F7',X'F8F97A5E4C7E6E6F', -C & X'7CC1C2C3C4C5C6C7',X'C8C9D1D2D3D4D5D6', -C & X'D7D8D9E2E3E4E5E6',X'E7E8E9ADE0BD5F6D', -C & X'7981828384858687',X'8889919293949596', -C & X'979899A2A3A4A5A6',X'A7A8A9C06AD0A107', -C & 16*X'4040404040404040'/ -C -C THIS TABLE IS THE SAME AS HDS ASSEMBLER VERSION -C - DATA IEBCDC/ - & X'007D006C000000E0',X'00657C66004C0000', - & X'0000000000000000',X'0000000000005B00', - & X'40D07F7B5000506E',X'4D5D5C4F6B604B61', - & X'F0F1F2F3F4F5F6F7',X'F8F90000007E00C0', - & X'64C1C2C3C4C5C6C7',X'C8C9D1D2D3D4D5D6', - & X'D7D8D9E2E3E4E5E6',X'E7E8E90062636D00', - & X'0000000000000000',X'0000000000000000', - & X'0000000000000000',X'000000000000005F', - & 16 * X'0000000000000000'/ -C - IF (N .LE. 0) RETURN -C -C*** CONVERT STRING ... ASCII TO EBCDIC, N CHARACTERS -C - DO 20 J = 1, N - NFLD(J) = EBCDIC(mova2i(NFLD(J))) - 20 CONTINUE -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3aq15.f b/external/w3nco/v2.0.6/src/w3aq15.f deleted file mode 100644 index 0f423c9fa..000000000 --- a/external/w3nco/v2.0.6/src/w3aq15.f +++ /dev/null @@ -1,66 +0,0 @@ - SUBROUTINE W3AQ15(ITIME, QDESCR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3AQ15 GMT TIME PACKER -C PRGMMR: R.E.JONES ORG: W/NMC421 DATE: 95-10-10 -C -C ABSTRACT: CONVERT 32 OR 64 BIT BINARY TIME (GMT) INTO A 16 BIT -C STRING AND STORE THESE 4 PACKED DECIMAL NUMBERS INTO BYTES -C 39 AND 40 OF THE OUTPUT ARRAY. -C -C PROGRAM HISTORY LOG: -C 83-12-12 B. STRUBLE (ORIGINAL AUTHOR) -C 84-07-06 R.E.JONES CHANGE TO IBM ASSEMBLER V 02 -C 95-10-16 R.E.JONES CHANGE TO FORTRAN FOR CRAY AND 32 BIT -C WORKSTATIONS -C -C USAGE: CALL W3AQ15(ITIME, QDESCR) -C INPUT ARGUMENT LIST: -C ITIME - INTEGER WORD CONTAINING TIME IN BINARY -C -C OUTPUT ARGUMENT LIST: -C QDESCR - ARRAY CONTAINING TRANSMISSION QUEUE DESCRIPTOR -C NOTE- TIME WILL BE PLACED IN 39 AND 40TH -C BYTE OF THIS ARRAY AS 4 (4 BIT) BCD. -C -C -C REMARKS: THE USER CAN OBTAIN THE CURRENT TIME IN GMT BY INVOCKING -C THE W3 LIBRARY ROUTINE W3FQ02 WHICH FILLS AN EIGHT WORD ARRAY -C WITH THE CURRENT DATE AND TIME. THE 5TH WORD FROM THIS ARRAY -C CONTAINS THE TIME WHICH CAN BE PASSED TO W3AQ15 AS THE -C INPUT PARAMETER-ITIME. -C -C -C EXAMPLE: -C -C INTEGER NTIME(8) -C CHARACTER * 80 QUEUE -C -C CALL W3FQ02(NTIME,0) -C CALL W3AQ15(NTIME(5),QUEUE) -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916/256, J916/2048. -C -C$$$ - INTEGER ITIME -C - CHARACTER * 80 QDESCR -C -C BYTES 39-40 HR/MIN TIME OF BULLETIN CREATION -C TWO BYTES AS 4 BIT BCD -C -C -C CONVERT INTO 4 BIT BCD -C - KA = ITIME / 1000 - KB = MOD(ITIME,1000) / 100 - KC = MOD(ITIME,100) / 10 - KD = MOD(ITIME,10) -C - QDESCR(39:39) = CHAR(KA * 16 + KB) - QDESCR(40:40) = CHAR(kC * 16 + KD) -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3as00.f b/external/w3nco/v2.0.6/src/w3as00.f deleted file mode 100644 index 26183554e..000000000 --- a/external/w3nco/v2.0.6/src/w3as00.f +++ /dev/null @@ -1,315 +0,0 @@ - subroutine W3AS00(nch_parm,cparm,iret_parm) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3AS00 GET PARM FIELD FROM COMMAND-LINE -C PRGMMR: SHIMOMURA ORG: W/NMC41 DATE: 95-05-23 -C -C ABSTRACT: TO GET THE ONE COMMAND-LINE ARGUMENT WHICH STARTS WITH -C "PARM="; RETURNING THE PARM FIELD (WITHOUT THE KEYWORD "PARM=") -C AS A NULL-TERMINATED STRING IN THE CHARACTER STRING:CPARM. -C -C PROGRAM HISTORY LOG: -C 95-05-23 DAVID SHIMOMURA -C 98-03-10 B. VUONG REMOVE THE CDIR$ INTEGER=64 DIRECTIVE -C -C USAGE: CALL W3AS00(NCH_PARM, CPARM, iret_parm) -C 1 2 3 -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C (1.) NCH_PARM - NO. OF CHARACTERS IN THE PARM FIELD -C (2.) CPARM - C*(*) CPARM -- THE DESTINATION FOR THE PARMFIELD -C OBTAINED FROM THE COMMAND LINE; -C USER SHOULD DEFINE THE CHARACTER STRING FOR -C A SIZE .LE. 101-BYTES, WHICH WOULD BE -C BIG ENOUGH FOR THE 100-CHAR IBM LIMIT PLUS -C ONE EXTRA BYTE FOR MY NULL-TERMINATOR. -C -C (3.) iret_parm - RETURN CODE -C = 0; NORMAL RETURN -C = -1; ABNORMAL EXIT. THE USER HAS FAILED -C TO DEFINE THE CPARM DESTINATION -C AS A CHARACTER STRING. -C -C = +1; A WARNING: -C THE GIVEN ARG IN THE COMMAND LINE WAS -C TOO LONG TO FIT IN THE DESTINATION: CPARM, -C SO I HAVE TRUNCATED IT. -C -C = +2; A WARNING: NO ARGS AT ALL ON COMMAND LINE, -C SO I COULD NOT FETCH THE PARM FIELD. -C -C = +3; A WARNING: NO "PARM="-ARGUMENT EXISTS -C AMONG THE ARGS ON THE COMMAND LINE, -C SO I COULD NOT FETCH THE PARM FIELD. -C -C OUTPUT FILES: -C FT06F001 - SOME CHECKOUT PRINTOUT -C -C REMARKS: -C -C TO EMULATE THE IBM PARM FIELD, THE USER SHOULD KEY_IN ON THE -C COMMAND LINE: -C PARM='IN BETWEEN THE SINGLE_QUOTES IS THE PARM FIELD' -C WHAT IS RETURNED FROM W3AS00() FROM THE PARM= ARG IS -C THE PARM FIELD: WHICH STARTS WITH THE LOCATION BEYOND THE -C EQUAL_SIGN OF THE KEYWORD "PARM=", AND INCLUDES EVERYTHING -C WHICH WAS WITHIN THE BOUNDS OF THE SINGLE-QUOTE SIGNS. -C BUT THE QUOTE SIGNS THEMSELVES WILL DISAPPEAR; AND A NULL- -C TERMINATOR WILL BE ADDED. -C THE STARTING "PARM=" IS A KEY WORD FOR THE PARMS, AND SHOULD -C NOT BE USED TO START ANY OTHER ARGUMENT. -C -C CAUTION: I HAVE CHANGED THE CALL SEQUENCE BY ADDING A RETURN CODE -C -C -C ATTRIBUTES: -C LANGUAGE: CRAY FORTRAN77 -C MACHINE: CRAY2 -C -C$$$ -C - integer kbytpwrd - parameter (kbytpwrd=8) - integer maxnbyt - parameter (maxnbyt=112) -C ... WHERE 112 CHARACTERS IS SIZE OF CWORK FOR 100 CHARACTERS -C ... WITHIN QUOTES + 'PARM=' + BACKSLASHES + LINEFEEDS - - integer maxnwrds - parameter (maxnwrds=maxnbyt/kbytpwrd) - -C ... call seq. args ... - INTEGER NCH_PARM - CHARACTER*(*) CPARM - integer iret_parm - -C -C ... FUNCTIONS ... - external lastch - integer lastch - external notrail - integer notrail -C ------------------------------------------------------------- - integer jwork(maxnwrds) - character*112 cwork - equivalence (jwork,cwork) - - integer(4) nargsinline,iargc,iar - integer nchars - integer lmt_txt - integer non_parm - - LOGICAL LPARMQQ - character*1 KLF - character*1 NULLCHR - character*1 lonech - -C . . . . . . . . S T A R T . . . . . . . . . . . . . . . . - - NULLCHR = char(0) - KLF = char(10) -C - iret_parm = 0 - non_parm = 0 - - LPARMQQ = .FALSE. - NCH_PARM = 0 - - lmt_dest = len(cparm) - write(6,103)lmt_dest - 103 format(1h ,'W3AS00: dimensioned size (in bytes) of dest strng=', - 1 I11) - if(lmt_dest .le. 0) then - write(6,105) - 105 format(1h ,'W3AS00:FAILED on undefined destination ', - 1 'character string: CPARM') - iret_parm = -1 - nch_parm = 0 - go to 999 - else if (lmt_dest .gt. 101) then - lmt_dest = 101 - endif - lmt_txt = lmt_dest - 1 - - cparm(1:lmt_dest) = ' ' - - narg_got = 0 -C - nargsinline = iargc() - - write(6,115) nargsinline - 115 format(1h ,'W3AS00: count of args found in command line =', I3) - - if(nargsinline .gt. 0) then -C ... to scan every argument, looking only for the Arg which -C ... starts with "PARM=" - do iar = 1,nargsinline - LPARMQQ = .FALSE. - - cwork(1:) = ' ' - - call getarg(iar,cwork) - - narg_got = narg_got + 1 - nchars = lastch(cwork) - - if(nchars .le. 0) then - write(6,125)iar - 125 format(1h ,'W3AS00:getarg() returned an empty arg for', - A ' no.',I3 ) - else -C ... SOME TEXT EXISTS IN THIS ARG ... -C ... DOES IT START WITH "PARM=" ??? - if((cwork(1:5) .EQ. 'PARM=') .OR. - 1 (cwork(1:5) .EQ. 'parm=') ) then - LPARMQQ = .TRUE. -C ... this arg is special case of PARM= -C ... which can include blanks, so cannot lastch() it ... - nchars = notrail(cwork) - endif -C ... iwdss = ((nchars-1)/kbytpwrd) + 1 -C ... where iwdss points to last word so I could hex dump -C ... that last word, to see if NULL is there -C ... There was no NULL; only blank fill. - IF(LPARMQQ) THEN -C ... FILTER OUT ANY BACKSLASH or LINE_FEED ... - ioutc = 0 - do inc = 6,nchars - if(ioutc .LT. lmt_txt) then - lonech = cwork(inc:inc) - if((lonech .EQ. '\\') .OR. - 1 (lonech .EQ. KLF)) then - else - ioutc = ioutc + 1 - cparm(ioutc:ioutc) = lonech - endif - else -C ... comes here if ioutc .GE. lmt_txt, -C ... so I cannot increment ioutc for this inc char -C ... so truncate the string at (1:ioutc) -C ... a warning be return-coded ... - iret_parm = +1 - go to 155 - endif - enddo - 155 continue - nch_parm = ioutc - np1 = nchars+1 - cparm(np1:np1) = NULLCHR - go to 999 -C ... jump out of DO when PARM has been processed ... - else -C ... this is .not. a PARM field, do nothing w/ those, - non_parm = non_parm + 1 - endif - - endif - enddo -C ... IF IT FALLS THRU BOTTOM OF DO, THEN IT DID NOT FIND -C ... THE PARM FIELD AMONG THE EXISTING ARGS - iret_parm = 3 - nch_parm = 0 - - ELSE -C ... COMES HERE IF nargsinline = 0, so there were no args at all - iret_parm = 2 - nch_parm = 0 - endif - go to 999 - - 999 continue - return - end - integer function lastch(str) -C ... lastch() ... to point to the last character of a character -C ... string -C ... String terminators are first BLANK or NULL character -C ... encountered. -C ... Caution: I will limit scan on LEN(str) -C so you must give me a character string. -C - - character*(*) str - - character*1 NULLCHR - character*1 BLANK -C - integer i - integer limit -C - NULLCHR = char(0) - BLANK = ' ' - limit = len(str) - i = 0 - do while(i .LT. limit .AND. str(i+1:i+1) .NE. NULLCHR - 1 .AND. str(i+1:i+1) .NE. BLANK) - i = i + 1 - enddo - - lastch = i - return - end - integer function notrail(str) -C ... mods for CRAY version 8-Dec-1994/dss -C -C ... notrail() ... to point to the last non-blank character of a -C ... character string (which can have leading -C blanks and intermediate blanks); but after -C ignoring all trailing blank characters. -C ... String terminators are last BLANK or first NULL -C ... character encountered. -C -C ... This differs from LASTCH() which stops on first -C ... BLANK encountered when scanning from the start; -C ... NOTRAIL() will scan backwards from the end of the -C ... string, skipping over trailing blanks, until the -C ... last non-blank character is hit. -C ... -C ... Caution: I will limit scan on LEN(str) -C so you must give me a character string. -C - - character*(*) str - - character*1 BLANK - parameter (BLANK = ' ') -C - integer i - integer limit - integer limitnl - character*1 NULLCHR -C - NULLCHR = char(0) - i = 0 - limitnl = 0 - limit = len(str) - if(limit .le. 0) go to 999 -C ... otherwise, at least one char len string ... - limitnl = index(str(1:limit),NULLCHR) - if(limitnl .le. 0) then -C ... no NULLCHR exists in str(1:limit) ... -C ... so go scan from limit - go to 300 - - else if(limitnl .eq. 1) then - go to 999 -C ... which jumped out w/ pointer=0 if NULL in first position - else -C ... a NULLCHR existed within str(1:limit); so -C ... I want to scan backwards from before that NULLCHR -C ... which is located at limitnl - limit = limitnl - 1 - endif - if(limit .le. 0) go to 999 - 300 continue -C ... otherwise, we have a string of at least one char to look at -C ... which has no NULLCHR in interval (1:limit) - i = limit - do while((i .GT. 0) .AND. (str(i:i) .EQ. BLANK)) - i = i - 1 - enddo - - 999 continue - notrail = i - return - end diff --git a/external/w3nco/v2.0.6/src/w3difdat.f b/external/w3nco/v2.0.6/src/w3difdat.f deleted file mode 100644 index 1e76b6e78..000000000 --- a/external/w3nco/v2.0.6/src/w3difdat.f +++ /dev/null @@ -1,55 +0,0 @@ -!----------------------------------------------------------------------- - subroutine w3difdat(jdat,idat,it,rinc) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3DIFDAT RETURN A TIME INTERVAL BETWEEN TWO DATES -! AUTHOR: MARK IREDELL ORG: WP23 DATE: 98-01-05 -! -! ABSTRACT: THIS SUBPROGRAM RETURNS THE ELAPSED TIME INTERVAL FROM -! AN NCEP ABSOLUTE DATE AND TIME GIVEN IN THE SECOND ARGUMENT UNTIL -! AN NCEP ABSOLUTE DATE AND TIME GIVEN IN THE FIRST ARGUMENT. -! THE OUTPUT TIME INTERVAL IS IN ONE OF SEVEN CANONICAL FORMS -! OF THE NCEP RELATIVE TIME INTERVAL DATA STRUCTURE. -! -! PROGRAM HISTORY LOG: -! 98-01-05 MARK IREDELL -! -! USAGE: CALL W3DIFDAT(JDAT,IDAT,IT,RINC) -! -! INPUT VARIABLES: -! JDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! IDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! IT INTEGER RELATIVE TIME INTERVAL FORMAT TYPE -! (-1 FOR FIRST REDUCED TYPE (HOURS ALWAYS POSITIVE), -! 0 FOR SECOND REDUCED TYPE (HOURS CAN BE NEGATIVE), -! 1 FOR DAYS ONLY, 2 FOR HOURS ONLY, 3 FOR MINUTES ONLY, -! 4 FOR SECONDS ONLY, 5 FOR MILLISECONDS ONLY) -! -! OUTPUT VARIABLES: -! RINC REAL (5) NCEP RELATIVE TIME INTERVAL -! (DAYS, HOURS, MINUTES, SECONDS, MILLISECONDS) -! (TIME INTERVAL IS POSITIVE IF JDAT IS LATER THAN IDAT.) -! -! SUBPROGRAMS CALLED: -! IW3JDN COMPUTE JULIAN DAY NUMBER -! W3REDDAT REDUCE A TIME INTERVAL TO A CANONICAL FORM -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - integer jdat(8),idat(8) - real rinc(5) - real rinc1(5) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! difference the days and time and put into canonical form - rinc1(1)=iw3jdn(jdat(1),jdat(2),jdat(3))- - & iw3jdn(idat(1),idat(2),idat(3)) - rinc1(2:5)=jdat(5:8)-idat(5:8) - call w3reddat(it,rinc1,rinc) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end diff --git a/external/w3nco/v2.0.6/src/w3doxdat.f b/external/w3nco/v2.0.6/src/w3doxdat.f deleted file mode 100644 index b36ad7c29..000000000 --- a/external/w3nco/v2.0.6/src/w3doxdat.f +++ /dev/null @@ -1,40 +0,0 @@ -!----------------------------------------------------------------------- - subroutine w3doxdat(idat,jdow,jdoy,jday) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3DOXDAT RETURN WEEK DAY, YEAR DAY, AND JULIAN DAY -! AUTHOR: MARK IREDELL ORG: WP23 DATE: 98-01-05 -! -! ABSTRACT: THIS SUBPROGRAM RETURNS THE INTEGER DAY OF WEEK, THE DAY -! OF YEAR, AND JULIAN DAY GIVEN AN NCEP ABSOLUTE DATE AND TIME. -! -! PROGRAM HISTORY LOG: -! 98-01-05 MARK IREDELL -! -! USAGE: CALL W3DOXDAT(IDAT,JDOW,JDOY,JDAY) -! -! INPUT VARIABLES: -! IDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! -! OUTPUT VARIABLES: -! JDOW INTEGER DAY OF WEEK (1-7, WHERE 1 IS SUNDAY) -! JDOY INTEGER DAY OF YEAR (1-366, WHERE 1 IS JANUARY 1) -! JDAY INTEGER JULIAN DAY (DAY NUMBER FROM JAN. 1,4713 B.C.) -! -! SUBPROGRAMS CALLED: -! IW3JDN COMPUTE JULIAN DAY NUMBER -! W3FS26 YEAR, MONTH, DAY FROM JULIAN DAY NUMBER -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - integer idat(8) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! get julian day and then get day of week and day of year - jday=iw3jdn(idat(1),idat(2),idat(3)) - call w3fs26(jday,jy,jm,jd,jdow,jdoy) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end diff --git a/external/w3nco/v2.0.6/src/w3fi01.f b/external/w3nco/v2.0.6/src/w3fi01.f deleted file mode 100644 index a4d87dbcc..000000000 --- a/external/w3nco/v2.0.6/src/w3fi01.f +++ /dev/null @@ -1,33 +0,0 @@ - SUBROUTINE W3FI01(LW) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI01 DETERMINES MACHINE WORD LENGTH IN BYTES -C PRGMMR: KEYSER ORG: W/NMC22 DATE: 06-29-92 -C -C ABSTRACT: DETERMINES THE NUMBER OF BYTES IN A FULL WORD FOR THE -C PARTICULAR MACHINE (IBM OR CRAY). -C -C PROGRAM HISTORY LOG: -C 92-01-10 R. KISTLER (W/NMC23) -C 92-05-22 D. A. KEYSER -- DOCBLOCKED/COMMENTED -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 2001-06-07 Gilbert Uses f90 standard routine bit_size to -C find integer word length -C -C USAGE: CALL W3FI01(LW) -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C LW - MACHINE WORD LENGTH IN BYTES -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY, WORKSTATIONS -C -C$$$ -C - INTEGER LW - LW=BIT_SIZE(LW) - LW=LW/8 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi04.f b/external/w3nco/v2.0.6/src/w3fi04.f deleted file mode 100644 index 72197daa1..000000000 --- a/external/w3nco/v2.0.6/src/w3fi04.f +++ /dev/null @@ -1,122 +0,0 @@ - SUBROUTINE W3FI04(IENDN,ITYPEC,LW) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: W3FI04 FIND WORD SIZE, ENDIAN, CHARACTER SET -C PRGMNR: JONES,R.E. ORG: W/NMC42 DATE: 94-10-07 -C -C ABSTRACT: SUBROUTINE COMPUTES WORD SIZE, THE TYPE OF CHARACTER -C SET, ASCII OR EBCDIC, AND IF THE COMPUTER IS BIG-ENDIAN, OR -C LITTLE-ENDIAN. -C -C PROGRAM HISTORY LOG: -C 94-10-07 R.E.JONES -C 98-07-08 Gilbert - Removed the Fortran SAVE Statement. -C The SAVE statement is not needed for this -C routine, and may have been causing errors -C using the f90 compiler under the 2.0 -C Programming Environment. -C 02-10-15 Vuong Replaced Function ICHAR with mova2i -C -C USAGE: CALL W3FI04 (IENDN, ITYPEC, LW) -C -C OUTPUT ARGUMENT LIST: -C IENDN - INTEGER FOR BIG-ENDIAN OR LITTLE-ENDIAN -C = 0 BIG-ENDIAN -C = 1 LITTLE-ENDIAN -C = 2 CANNOT COMPUTE -C ITYPEC - INTEGER FOR TYPE OF CHARACTER SET -C = 0 ASCII CHARACTER SET -C = 1 EBCDIC CHARACTER SET -C = 2 NOT ASCII OR EBCDIC -C LW - INTEGER FOR WORDS SIZE OF COMPUTER IN BYTES -C = 4 FOR 32 BIT COMPUTERS -C = 8 FOR 64 BIT COMPUTERS -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916/256, Y-MP8/64, Y-MP EL92/256, J916/2048 -C -C$$$ -C - INTEGER ITEST1 - INTEGER ITEST2 - INTEGER ITEST3 - INTEGER IENDN - INTEGER ITYPEC - INTEGER LW -C - CHARACTER * 8 CTEST1 - CHARACTER * 8 CTEST2 - CHARACTER * 1 CTEST3(8) - CHARACTER * 1 BLANK -C - EQUIVALENCE (CTEST1,ITEST1),(CTEST2,ITEST2) -C - EQUIVALENCE (ITEST3,CTEST3(1)) -C - DATA CTEST1/'12345678'/ - DATA ITEST3/Z'01020304'/ - DATA BLANK /' '/ -C -C SAVE -C -C TEST FOR TYPE OF CHARACTER SET -C BLANK IS 32 (20 HEX) IN ASCII, 64 (40 HEX) IN EBCDEC -C - IF (MOVA2I(BLANK).EQ.32) THEN - ITYPEC = 0 - ELSE IF (MOVA2I(BLANK).EQ.64) THEN -C -C COMPUTER IS PROBABLY AN IBM360, 370, OR 390 WITH -C A 32 BIT WORD SIZE, AND BIG-ENDIAN. -C - ITYPEC = 1 - ELSE - ITYPEC = 2 - END IF -C -C TEST FOR WORD SIZE, SET LW TO 4 FOR 32 BIT COMPUTER, -C 8 FOR FOR 64 BIT COMPUTERS -C - ITEST2 = ITEST1 - IF (CTEST1 .EQ. CTEST2) THEN -C -C COMPUTER MAY BE A CRAY, OR COULD BE DEC VAX ALPHA -C OR SGI WITH R4000, R4400, R8800 AFTER THEY CHANGE -C FORTRAN COMPILERS FOR 64 BIT INTEGER. -C - LW = 8 - ELSE - LW = 4 - ENDIF -C -C USING ITEST3 WITH Z'01020304' EQUIVALNCED TO CTEST3 -C ON A 32 BIT BIG-ENDIAN COMPUTER 03 IS IN THE 3RD -C BYTE OF A 4 BYTE WORD. ON A 32 BIT LITTLE-ENDIAN -C COMPUTER IT IS IN 2ND BYTE. -C ON A 64 BIT COMPUTER Z'01020304' IS RIGHT ADJUSTED IN -C A 64 BIT WORD, 03 IS IN THE 7TH BYTE. ON A LITTLE- -C ENDIAN 64 BIT COMPUTER IT IS IN THE 2ND BYTE. -C - IF (LW.EQ.4) THEN - IF (MOVA2I(CTEST3(3)).EQ.3) THEN - IENDN = 0 - ELSE IF (MOVA2I(CTEST3(3)).EQ.2) THEN - IENDN = 1 - ELSE - IENDN = 2 - END IF - ELSE IF (LW.EQ.8) THEN - IF (MOVA2I(CTEST3(7)).EQ.3) THEN - IENDN = 0 - ELSE IF (MOVA2I(CTEST3(2)).EQ.3) THEN - IENDN = 1 - ELSE - IENDN = 2 - END IF - ELSE - IENDN = 2 - END IF -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi58.f b/external/w3nco/v2.0.6/src/w3fi58.f deleted file mode 100644 index ec8ccf3e4..000000000 --- a/external/w3nco/v2.0.6/src/w3fi58.f +++ /dev/null @@ -1,115 +0,0 @@ - SUBROUTINE W3FI58(IFIELD,NPTS,NWORK,NPFLD,NBITS,LEN,KMIN) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK *** -C . . . . -C SUBPROGRAM: W3FI58 - PACK POSITIVE DIFFERENCES IN LEAST BITS -C PRGMMR: ALLARD, R. ORG: NMC411 DATE: JULY 1987 -C -C ABSTRACT: CONVERTS AN ARRAY OF INTEGER NUMBERS INTO AN ARRAY OF -C POSITIVE DIFFERENCES (NUMBER(S) - MINIMUM VALUE) AND PACKS THE -C MAGNITUDE OF EACH DIFFERENCE RIGHT-ADJUSTED INTO THE LEAST -C NUMBER OF BITS THAT HOLDS THE LARGEST DIFFERENCE. -C -C PROGRAM HISTORY LOG: -C 87-09-02 ALLARD -C 88-10-02 R.E.JONES CONVERTED TO CDC CYBER 205 FTN200 FORTRAN -C 90-05-17 R.E.JONES CONVERTED TO CRAY CFT77 FORTRAN -C 90-05-18 R.E.JONES CHANGE NAME VBIMPK TO W3LIB NAME W3FI58 -C 96-05-14 IREDELL GENERALIZED COMPUTATION OF NBITS -C 98-06-30 EBISUZAKI LINUX PORT -C -C USAGE: CALL W3FI58(IFIELD,NPTS,NWORK,NPFLD,NBITS,LEN,KMIN) -C -C INPUT: -C -C IFIELD - ARRAY OF INTEGER DATA FOR PROCESSING -C NPTS - NUMBER OF DATA VALUES TO PROCESS IN IFIELD (AND NWORK) -C WHERE, NPTS > 0 -C -C OUTPUT: -C -C NWORK - WORK ARRAY WITH INTEGER DIFFERENCE -C NPFLD - ARRAY FOR PACKED DATA (character*1) -C (USER IS RESPONSIBLE FOR AN ADEQUATE DIMENSION.) -C NBITS - NUMBER OF BITS USED TO PACK DATA WHERE, 0 < NBITS < 32 -C (THE MAXIMUM DIFFERENCE WITHOUT OVERFLOW IS 2**31 -1) -C LEN - NUMBER OF PACKED BYTES IN NPFLD (SET TO 0 IF NO PACKING) -C WHERE, LEN = (NBITS * NPTS + 7) / 8 WITHOUT REMAINDER -C KMIN - MINIMUM VALUE (SUBTRACTED FROM EACH DATUM). IF THIS -C PACKED DATA IS BEING USED FOR GRIB DATA, THE -C PROGRAMER WILL HAVE TO CONVERT THE KMIN VALUE TO AN -C IBM370 32 BIT FLOATING POINT NUMBER. -C -C SUBPROGRAMS CALLED: -C -C W3LIB: SBYTES, SBYTE -C -C EXIT STATES: NONE -C -C NOTE: LEN = 0, NBITS = 0, AND NO PACKING PERFORMED IF -C -C (1) KMAX = KMIN (A CONSTANT FIELD) -C (2) NPTS < 1 (SEE INPUT ARGUMENT) -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C - PARAMETER(ALOG2=0.69314718056) - INTEGER IFIELD(*) - CHARACTER*1 NPFLD(*) - INTEGER NWORK(*) -C - DATA KZERO / 0 / -C -C / / / / / / -C - LEN = 0 - NBITS = 0 - IF (NPTS.LE.0) GO TO 3000 -C -C FIND THE MAX-MIN VALUES IN INTEGER FIELD (IFIELD). -C - KMAX = IFIELD(1) - KMIN = KMAX - DO 1000 I = 2,NPTS - KMAX = MAX(KMAX,IFIELD(I)) - KMIN = MIN(KMIN,IFIELD(I)) - 1000 CONTINUE -C -C IF A CONSTANT FIELD, RETURN WITH NO PACKING AND 'LEN' AND 'NBITS' SET -C TO ZERO. -C - IF (KMAX.EQ.KMIN) GO TO 3000 -C -C DETERMINE LARGEST DIFFERENCE IN IFIELD AND FLOAT (BIGDIF). -C - BIGDIF = KMAX - KMIN -C -C NBITS IS COMPUTED AS THE LEAST INTEGER SUCH THAT -C BIGDIF < 2**NBITS -C - NBITS=LOG(BIGDIF+0.5)/ALOG2+1 -C -C FORM DIFFERENCES IN NWORK ARRAY. -C - DO 2000 K = 1,NPTS - NWORK(K) = IFIELD(K) - KMIN - 2000 CONTINUE -C -C PACK EACH MAGNITUDE IN NBITS (NBITS = THE LEAST POWER OF 2 OR 'N') -C - LEN=(NBITS*NPTS-1)/8+1 - CALL SBYTESC(NPFLD,NWORK,0,NBITS,0,NPTS) -C -C ADD ZERO-BITS AT END OF PACKED DATA TO INSURE A BYTE BOUNDARY. -C - NOFF = NBITS * NPTS - NZERO=LEN*8-NOFF - IF(NZERO.GT.0) CALL SBYTEC(NPFLD,KZERO,NOFF,NZERO) -C - 3000 CONTINUE - RETURN -C - END diff --git a/external/w3nco/v2.0.6/src/w3fi59.f b/external/w3nco/v2.0.6/src/w3fi59.f deleted file mode 100644 index ac430d4a9..000000000 --- a/external/w3nco/v2.0.6/src/w3fi59.f +++ /dev/null @@ -1,129 +0,0 @@ - SUBROUTINE W3FI59(FIELD,NPTS,NBITS,NWORK,NPFLD,ISCALE,LEN,RMIN) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI59 FORM AND PACK POSITIVE, SCALED DIFFERENCES -C PRGMMR: ALLARD, R. ORG: NMC41 DATE: 84-08-01 -C -C ABSTRACT: CONVERTS AN ARRAY OF SINGLE PRECISION REAL NUMBERS INTO -C AN ARRAY OF POSITIVE SCALED DIFFERENCES (NUMBER(S) - MINIMUM VALUE), -C IN INTEGER FORMAT AND PACKS THE ARGUMENT-SPECIFIED NUMBER OF -C SIGNIFICANT BITS FROM EACH DIFFERENCE. -C -C PROGRAM HISTORY LOG: -C 84-08-01 ALLARD ORIGINAL AUTHOR -C 90-05-17 R.E.JONES CONVERT TO CRAY CFT77 FORTRAN -C 90-05-18 R.E.JONES CHANGE NAME PAKMAG TO W3LIB NAME W3FI59 -C 93-07-06 R.E.JONES ADD NINT TO DO LOOP 2000 SO NUMBERS ARE -C ROUNDED TO NEAREST INTEGER, NOT TRUNCATED. -C 94-01-05 IREDELL COMPUTATION OF ISCALE FIXED WITH RESPECT TO -C THE 93-07-06 CHANGE. -C 98-06-30 EBISUZAKI LINUX PORT -C -C USAGE: CALL W3FI59(FIELD,NPTS,NBITS,NWORK,NPFLD,ISCALE,LEN,RMIN) -C INPUT ARGUMENT LIST: -C FIELD - ARRAY OF FLOATING POINT DATA FOR PROCESSING (REAL) -C NPTS - NUMBER OF DATA VALUES TO PROCESS IN FIELD (AND NWORK) -C WHERE, NPTS > 0 -C NBITS - NUMBER OF SIGNIFICANT BITS OF PROCESSED DATA TO BE PACKED -C WHERE, 0 < NBITS < 32+1 -C -C OUTPUT ARGUMENT LIST: -C NWORK - ARRAY FOR INTEGER CONVERSION (INTEGER) -C IF PACKING PERFORMED (SEE NOTE BELOW), THE ARRAY WILL -C CONTAIN THE PRE-PACKED, RIGHT ADJUSTED, SCALED, INTEGER -C DIFFERENCES UPON RETURN TO THE USER. -C (THE USER MAY EQUIVALENCE FIELD AND NWORK. SAME SIZE.) -C NPFLD - ARRAY FOR PACKED DATA (character*1) -C (DIMENSION MUST BE AT LEAST (NBITS * NPTS) / 64 + 1 ) -C ISCALE- POWER OF 2 FOR RESTORING DATA, SUCH THAT -C DATUM = (DIFFERENCE * 2**ISCALE) + RMIN -C LEN - NUMBER OF PACKED BYTES IN NPFLD (SET TO 0 IF NO PACKING) -C WHERE, LEN = (NBITS * NPTS + 7) / 8 WITHOUT REMAINDER -C RMIN - MINIMUM VALUE (REFERENCE VALUE SUBTRACTED FROM INPUT DATA) -C THIS IS A CRAY FLOATING POINT NUMBER, IT WILL HAVE TO BE -C CONVERTED TO AN IBM370 32 BIT FLOATING POINT NUMBER AT -C SOME POINT IN YOUR PROGRAM IF YOU ARE PACKING GRIB DATA. -C -C REMARKS: LEN = 0 AND NO PACKING PERFORMED IF -C -C (1) RMAX = RMIN (A CONSTANT FIELD) -C (2) NBITS VALUE OUT OF RANGE (SEE INPUT ARGUMENT) -C (3) NPTS VALUE LESS THAN 1 (SEE INPUT ARGUMENT) -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916/256, Y-MP8/864, Y-MP EL92/256, J916/2048 -C -C$$$ -C NATURAL LOGARITHM OF 2 AND 0.5 PLUS NOMINAL SAFE EPSILON - PARAMETER(ALOG2=0.69314718056,HPEPS=0.500001) -C - REAL FIELD(*) -C - CHARACTER*1 NPFLD(*) - INTEGER NWORK(*) -C - DATA KZERO / 0 / -C -C / / / / / / -C - LEN = 0 - ISCALE = 0 - IF (NBITS.LE.0.OR.NBITS.GT.32) GO TO 3000 - IF (NPTS.LE.0) GO TO 3000 -C -C FIND THE MAX-MIN VALUES IN FIELD. -C - RMAX = FIELD(1) - RMIN = RMAX - DO 1000 K = 2,NPTS - RMAX = AMAX1(RMAX,FIELD(K)) - RMIN = AMIN1(RMIN,FIELD(K)) - 1000 CONTINUE -C -C IF A CONSTANT FIELD, RETURN WITH NO PACKING PERFORMED AND 'LEN' = 0. -C - IF (RMAX.EQ.RMIN) GO TO 3000 -C -C DETERMINE LARGEST DIFFERENCE IN FIELD (BIGDIF). -C - BIGDIF = RMAX - RMIN -C -C ISCALE IS THE POWER OF 2 REQUIRED TO RESTORE THE PACKED DATA. -C ISCALE IS COMPUTED AS THE LEAST INTEGER SUCH THAT -C BIGDIF*2**(-ISCALE) < 2**NBITS-0.5 -C IN ORDER TO ENSURE THAT THE PACKED INTEGERS (COMPUTED IN LOOP 2000 -C WITH THE NEAREST INTEGER FUNCTION) STAY LESS THAN 2**NBITS. -C - ISCALE=NINT(ALOG(BIGDIF/(2.**NBITS-0.5))/ALOG2+HPEPS) -C -C FORM DIFFERENCES, RESCALE, AND CONVERT TO INTEGER FORMAT. -C - TWON = 2.0 ** (-ISCALE) - DO 2000 K = 1,NPTS - NWORK(K) = NINT( (FIELD(K) - RMIN) * TWON ) - 2000 CONTINUE -C -C PACK THE MAGNITUDES (RIGHTMOST NBITS OF EACH WORD). -C - KOFF = 0 - ISKIP = 0 -C -C USE NCAR ARRAY BIT PACKER SBYTES (GBYTES PACKAGE) -C - CALL SBYTESC(NPFLD,NWORK,KOFF,NBITS,ISKIP,NPTS) -C -C ADD 7 ZERO-BITS AT END OF PACKED DATA TO INSURE BYTE BOUNDARY. -C USE NCAR WORD BIT PACKER SBYTE -C - NOFF = NBITS * NPTS - CALL SBYTEC(NPFLD,KZERO,NOFF,7) -C -C DETERMINE BYTE LENGTH (LEN) OF PACKED FIELD (NPFLD). -C - LEN = (NOFF + 7) / 8 -C - 3000 CONTINUE - RETURN -C - END diff --git a/external/w3nco/v2.0.6/src/w3fi62.f b/external/w3nco/v2.0.6/src/w3fi62.f deleted file mode 100644 index 333f0fae3..000000000 --- a/external/w3nco/v2.0.6/src/w3fi62.f +++ /dev/null @@ -1,215 +0,0 @@ - SUBROUTINE W3FI62 (LOC,TTAAII,KARY,IERR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI62 BUILD 80-CHAR ON295 QUEUE DESCRIPTOR -C PRGMMR: CAVANAUGH ORG: NMC421 DATE:94-03-23 -C -C ABSTRACT: BUILD 80 CHARACTER QUEUE DESCRIPTOR USING INFORMATION -C SUPPLIED BY USER, PLACING THE COMPLETED QUEUE DESCRIPTOR IN THE -C LOCATION SPECIFIED BY THE USER. (BASED ON OFFICE NOTE 295). -C -C PROGRAM HISTORY LOG: -C 91-06-21 CAVANAUGH -C 94-03-08 CAVANAUGH MODIFIED TO ALLOW FOR BULLETIN SIZES THAT -C EXCEED 20000 BYTES -C 94-04-28 R.E.JONES CHANGE FOR CRAY 64 BIT WORD SIZE AND -C FOR ASCII CHARACTER SET COMPUTERS -C 96-01-29 R.E.JONES PRESET IERR TO ZERO -C 02-10-15 VUONG REPLACED FUNCTION ICHAR WITH MOVA2I -C -C USAGE: CALL W3FI62 (LOC,TTAAII,KARY,IERR) -C INPUT ARGUMENT LIST: -C TTAAII - FIRST 6 CHARACTERS OF WMO HEADER -C KARY - INTEGER ARRAY CONTAINING USER INFORMATION -C (1) = DAY OF MONTH -C (2) = HOUR OF DAY -C (3) = HOUR * 100 + MINUTE -C (4) = CATALOG NUMBER -C (5) = NUMBER OF 80 BYTE INCREMENTS -C (6) = NUMBER OF BYTES IN LAST INCREMENT -C (7) = TOTAL SIZE OF MESSAGE -C WMO HEADER + BODY OF MESSAGE IN BYTES -C (NOT INCLUDING QUEUE DESCRIPTOR) -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C LOC - LOCATION TO RECEIVE QUEUE DESCRIPTOR -C KARY - SEE INPUT ARGUMENT LIST -C IERR - ERROR RETURN -C -C SUBPROGRAMS CALLED: (LIST ALL CALLED FROM ANYWHERE IN CODES) -C LIBRARY: -C W3LIB - GBYTE W3FI01 W3AI15 -C -C REMARKS: IF TOTAL SIZE IS ENTERED (KARY(7)) THEN KARY(5) AND -C KARY(6) WILL BE CALCULATED. -C IF KARY(5) AND KARY(6) ARE PROVIDED THEN KARY(7) WILL -C BE IGNORED. -C -C WARNING: EQUIVALENCE ARRAY LOC TO INTEGER ARRAY SO IT STARTS ON -C A WORD BOUNDARY FOR SBYTE SUBROUTINE. -C -C ERROR RETURNS -C IERR = 1 TOTAL BYTE COUNT AND/OR 80 BYTE INCREMENT -C COUNT IS MISSING. ONE OR THE OTHER IS -C REQUIRED TO COMPLETE THE QUEUE DESCRIPTOR. -C IERR = 2 TOTAL SIZE TOO SMALL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS -C -C$$$ -C - INTEGER IHOLD(2) - INTEGER KARY(7),II,IERR -C - LOGICAL IBM370 -C - CHARACTER*6 TTAAII,AHOLD - CHARACTER*80 LOC - CHARACTER*1 BLANK -C - EQUIVALENCE (AHOLD,IHOLD) -C - SAVE -C -C BLANK WILL BE 40 HEX OR DECIMAL 64 ON AN IBM370 TYPE -C COMPUTER, THIS IS THE EBCDIC CHARACTER SET. -C BLANK WILL BE 20 HEX OR DECIMAL 32 ON A COMPUTER WITH THE -C ASCII CHARACTER SET. THIS WILL BE USED TO TEST FOR CHARACTER -C SETS TO FIND IBM370 TYPE COMPUTER. -C - DATA BLANK /' '/ -C ---------------------------------------------------------------- -C -C TEST FOR CRAY 64 BIT COMPUTER, LW = 8 -C - CALL W3FI01(LW) -C -C TEST FOR EBCDIC CHARACTER SET -C - IBM370 = .FALSE. - IF (MOVA2I(BLANK).EQ.64) THEN - IBM370 = .TRUE. - END IF -C - INOFST = 0 -C BYTES 1-16 'QUEUE DESCRIPTOR' - CALL SBYTE (LOC,-656095772,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,-985611067,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,-490481207,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,-672934183,INOFST,32) - INOFST = INOFST + 32 -C BYTES 17-20 INTEGER ZEROES - CALL SBYTE (LOC,0,INOFST,32) - INOFST = INOFST + 32 -C IF TOTAL COUNT IS INCLUDED -C THEN WILL DETERMINE THE NUMBER OF -C 80 BYTE INCREMENTS AND WILL DETERMINE -C THE NUMBER OF BYTES IN THE LAST INCREMENT - IERR = 0 - IF (KARY(7).NE.0) THEN - IF (KARY(7).LT.35) THEN -C PRINT *,'LESS THAN MINIMUM SIZE' - IERR = 2 - RETURN - END IF - KARY(5) = KARY(7) / 80 - KARY(6) = MOD(KARY(7),80) - IF (KARY(6).EQ.0) THEN - KARY(6) = 80 - ELSE - KARY(5) = KARY(5) + 1 - END IF - ELSE - IF (KARY(5).LT.1) THEN - IERR = 1 - RETURN - END IF - END IF -C BYTE 21-22 NR OF 80 BYTE INCREMENTS - CALL SBYTE (LOC,KARY(5),INOFST,16) - INOFST = INOFST + 16 -C BYTE 23 NR OF BYTES IN LAST INCREMENT - CALL SBYTE (LOC,KARY(6),INOFST,8) - INOFST = INOFST + 8 -C BYTES 24-28 INTEGER ZEROES - CALL SBYTE (LOC,0,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,0,INOFST,8) - INOFST = INOFST + 8 -C BYTES 29-34 6 CHAR BULLETIN NAME TTAAII - LOC(29:34) = TTAAII(1:6) -C -C IF ON ASCII COMPUTER, CONVERT LAST 6 CHARACTERS TO EBCDIC -C - IF (.NOT.IBM370) CALL W3AI39(LOC(29:29),6) -C - INOFST = INOFST + 48 -C BYTES 35-38 DAY OF MONTH AND UTC(Z) HRS -C DAY -C -C NOTE: W3AI15 WILL MAKE ASCII OR EBCDIC CHARACTERS -C DEPENDING ON WHAT TYPE OF COMPUTER IT IS ON -C - CALL W3AI15 (KARY(1),II,1,LW,'-') - CALL SBYTE (LOC,II,INOFST,16) - INOFST = INOFST + 16 -C HOURS - CALL W3AI15 (KARY(2),II,1,LW,'-') - CALL SBYTE (LOC,II,INOFST,16) -C -C IF ON ASCII COMPUTER, CONVERT LAST 4 CHARACTERS TO EBCDIC -C - IF (.NOT.IBM370) CALL W3AI39(LOC(35:35),4) - INOFST = INOFST + 16 -C BYTES 39-40 HR/MIN TIME OF BULLETIN CREATION -C TWO BYTES AS 4 BIT BCD - KA = KARY(3) / 1000 - KB = MOD(KARY(3),1000) / 100 - KC = MOD(KARY(3),100) / 10 - KD = MOD(KARY(3),10) - CALL SBYTE (LOC,KA,INOFST,4) - INOFST = INOFST + 4 - CALL SBYTE (LOC,KB,INOFST,4) - INOFST = INOFST + 4 - CALL SBYTE (LOC,KC,INOFST,4) - INOFST = INOFST + 4 - CALL SBYTE (LOC,KD,INOFST,4) - INOFST = INOFST + 4 -C BYTES 41-45 CATALOG NUMBER ELSE (SET TO 55555) - IF (KARY(4).GE.1.AND.KARY(4).LE.99999) THEN - CALL W3AI15 (KARY(4),IHOLD,1,8,'-') - IF (LW.EQ.4) THEN - CALL SBYTE (LOC,IHOLD(1),INOFST,8) - INOFST = INOFST + 8 - CALL SBYTE (LOC,IHOLD(2),INOFST,32) - INOFST = INOFST + 32 -C -C ON CRAY 64 BIT COMPUTER -C - ELSE - CALL SBYTE (LOC,IHOLD,INOFST,40) - INOFST = INOFST + 40 - END IF -C -C IF ON ASCII COMPUTER, CONVERT LAST 5 CHARACTERS TO EBCDIC -C - IF (.NOT.IBM370) CALL W3AI39(LOC(41:41),5) - ELSE - CALL SBYTE (LOC,-168430091,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,245,INOFST,8) - INOFST = INOFST + 8 - END IF -C BYTES 46-80 INTEGER ZEROES - DO 4676 I = 1, 8 - CALL SBYTE (LOC,0,INOFST,32) - INOFST = INOFST + 32 - 4676 CONTINUE - CALL SBYTE (LOC,0,INOFST,24) - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi63.f b/external/w3nco/v2.0.6/src/w3fi63.f deleted file mode 100644 index ea17f45c6..000000000 --- a/external/w3nco/v2.0.6/src/w3fi63.f +++ /dev/null @@ -1,4062 +0,0 @@ - SUBROUTINE W3FI63(MSGA,KPDS,KGDS,KBMS,DATA,KPTR,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI63 UNPK GRIB FIELD TO GRIB GRID -C PRGMMR: FARLEY ORG: NMC421 DATE:94-11-22 -C -C ABSTRACT: UNPACK A GRIB (EDITION 1) FIELD TO THE EXACT GRID -C SPECIFIED IN THE GRIB MESSAGE, ISOLATE THE BIT MAP, AND MAKE -C THE VALUES OF THE PRODUCT DESCRIPTON SECTION (PDS) AND THE -C GRID DESCRIPTION SECTION (GDS) AVAILABLE IN RETURN ARRAYS. -C -C WHEN DECODING IS COMPLETED, DATA AT EACH GRID POINT HAS BEEN -C RETURNED IN THE UNITS SPECIFIED IN THE GRIB MANUAL. -C -C PROGRAM HISTORY LOG: -C 91-09-13 CAVANAUGH -C 91-11-12 CAVANAUGH MODIFIED SIZE OF ECMWF GRIDS 5-8 -C 91-12-22 CAVANAUGH CORRECTED PROCESSING OF MERCATOR PROJECTIONS -C IN GRID DEFINITION SECTION (GDS) IN -C ROUTINE FI633 -C 92-08-05 CAVANAUGH CORRECTED MAXIMUM GRID SIZE TO ALLOW FOR -C ONE DEGREE BY ONE DEGREE GLOBAL GRIDS -C 92-08-27 CAVANAUGH CORRECTED TYPO ERROR, ADDED CODE TO COMPARE -C TOTAL BYTE SIZE FROM SECTION 0 WITH SUM OF -C SECTION SIZES. -C 92-10-21 CAVANAUGH CORRECTIONS WERE MADE (IN FI634) TO REDUCE -C PROCESSING TIME FOR INTERNATIONAL GRIDS. -C REMOVED A TYPOGRAPHICAL ERROR IN FI635. -C 93-01-07 CAVANAUGH CORRECTIONS WERE MADE (IN FI635) TO -C FACILITATE USE OF THESE ROUTINES ON A PC. -C A TYPOGRAPHICAL ERROR WAS ALSO CORRECTED -C 93-01-13 CAVANAUGH CORRECTIONS WERE MADE (IN FI632) TO -C PROPERLY HANDLE CONDITION WHEN -C TIME RANGE INDICATOR = 10. -C ADDED U.S.GRID 87. -C 93-02-04 CAVANAUGH ADDED U.S.GRIDS 85 AND 86 -C 93-02-26 CAVANAUGH ADDED GRIDS 2, 3, 37 THRU 44,AND -C GRIDS 55, 56, 90, 91, 92, AND 93 TO -C LIST OF U.S. GRIDS. -C 93-04-07 CAVANAUGH ADDED GRIDS 67 THRU 77 TO -C LIST OF U.S. GRIDS. -C 93-04-20 CAVANAUGH INCREASED MAX SIZE TO ACCOMODATE -C GAUSSIAN GRIDS. -C 93-05-26 CAVANAUGH CORRECTED GRID RANGE SELECTION IN FI634 -C FOR RANGES 67-71 & 75-77 -C 93-06-08 CAVANAUGH CORRECTED FI635 TO ACCEPT GRIB MESSAGES -C WITH SECOND ORDER PACKING. ADDED ROUTINE FI636 -C TO PROCESS MESSAGES WITH SECOND ORDER PACKING. -C 93-09-22 CAVANAUGH MODIFIED TO EXTRACT SUB-CENTER NUMBER FROM -C PDS BYTE 26 -C 93-10-13 CAVANAUGH MODIFIED FI634 TO CORRECT GRID SIZES FOR -C GRIDS 204 AND 208 -C 93-10-14 CAVANAUGH INCREASED SIZE OF KGDS TO INCLUDE ENTRIES FOR -C NUMBER OF POINTS IN GRID AND NUMBER OF WORDS -C IN EACH ROW -C 93-12-08 CAVANAUGH CORRECTED TEST FOR EDITION NUMBER INSTEAD -C OF VERSION NUMBER -C 93-12-15 CAVANAUGH MODIFIED SECOND ORDER POINTERS TO FIRST ORDER -C VALUES AND SECOND ORDER VALUES CORRECTLY -C IN ROUTINE FI636 -C 94-03-02 CAVANAUGH ADDED CALL TO W3FI83 WITHIN DECODER. USER -C NO LONGER NEEDS TO MAKE CALL TO THIS ROUTINE -C 94-04-22 CAVANAUGH MODIFIED FI635, FI636 TO PROCESS ROW BY ROW -C SECOND ORDER PACKING, ADDED SCALING CORRECTION -C TO FI635, AND CORRECTED TYPOGRAPHICAL ERRORS -C IN COMMENT FIELDS IN FI634 -C 94-05-17 CAVANAUGH CORRECTED ERROR IN FI633 TO EXTRACT RESOLUTION -C FOR LAMBERT-CONFORMAL GRIDS. ADDED CLARIFYING -C INFORMATION TO DOCBLOCK ENTRIES -C 94-05-25 CAVANAUGH ADDED CODE TO PROCESS COLUMN BY COLUMN AS WELL -C AS ROW BY ROW ORDERING OF SECOND ORDER DATA -C 94-06-27 CAVANAUGH ADDED PROCESSING FOR GRIDS 45, 94 AND 95. -C INCLUDES CONSTRUCTION OF SECOND ORDER BIT MAPS -C FOR THINNED GRIDS IN FI636. -C 94-07-08 CAVANAUGH COMMENTED OUT PRINT OUTS USED FOR DEBUGGING -C 94-09-08 CAVANAUGH ADDED GRIDS 220, 221, 223 FOR FNOC -C 94-11-10 FARLEY INCREASED MXSIZE FROM 72960 TO 260000 -C FOR .5 DEGREE SST ANALYSIS FIELDS -C 94-12-06 R.E.JONES CHANGES IN FI632 FOR PDS GREATER THAN 28 -C 95-02-14 R.E.JONES CORRECT IN FI633 FOR NAVY WAFS GRIB -C 95-03-20 M.BALDWIN FI633 MODIFICATION TO GET -C DATA REP TYPES [KGDS(1)] 201 AND 202 TO WORK. -C 95-04-10 E.ROGERS ADDED GRIDS 96 AND 97 FOR ETA MODEL IN FI634. -C 95-04-26 R.E.JONES FI636 CORECTION FOR 2ND ORDER COMPLEX -C UNPACKING. R -C 95-05-19 R.E.JONES ADDED GRID 215, 20 KM AWIPS GRID -C 95-07-06 R.E.JONES ADDED GAUSSIAN T62, T126 GRID 98, 126 -C 95-10-19 R.E.JONES ADDED GRID 216, 45 KM ETA AWIPS ALASKA GRID -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 96-03-07 R.E.JONES CONTINUE UNPACK WITH KRET ERROR 9 IN FI631. -C 96-08-19 R.E.JONES ADDED MERCATOR GRIDS 8 AND 53, AND GRID 196 -C 97-02-12 W BOSTELMAN CORRECTS ECMWF US GRID 2 PROCESSING -C 98-06-17 IREDELL REMOVED ALTERNATE RETURN IN FI637 -C 98-08-31 IREDELL ELIMINATED NEED FOR MXSIZE -C 98-09-02 Gilbert Corrected error in map size for U.S. Grid 92 -C 98-09-08 BALDWIN ADD DATA REP TYPE [KGDS(1)] 203 -C 01-03-08 ROGERS CHANGED ETA GRIDS 90-97, ADDED ETA GRIDS -C 194, 198. ADDED AWIPS GRIDS 241,242,243, -C 245, 246, 247, 248, AND 250 -C 01-03-19 VUONG ADDED AWIPS GRIDS 238,239,240, AND 244 -C 2001-06-06 GILBERT Changed gbyte/sbyte calls to refer to -C Wesley Ebisuzaki's endian independent -C versions gbytec/sbytec. -C Removed equivalences. -C 01-05-03 ROGERS ADDED GRID 249 (12KM FOR ALASKA) -C 01-10-10 ROGERS REDEFINED GRID 218 FOR 12 KM ETA -C REDEFINED GRID 192 FOR NEW 32-KM ETA GRID -C 02-03-27 VUONG ADDED RSAS GRID 88 AND AWIPS GRIDS 219, 220, -C 223, 224, 225, 226, 227, 228, 229, 230, 231, -C 232, 233, 234, 235, 251, AND 252 -C 02-08-06 ROGERS REDEFINED GRIDS 90-93,97,194,245-250 FOR THE -C 8KM HI-RES-WINDOW MODEL AND ADD AWIPS GRID 253 -C 2003-06-30 GILBERT SET NEW VALUES IN ARRAY KPTR TO PASS BACK ADDITIONAL -C PACKING INFO. -C KPTR(19) - BINARY SCALE FACTOR -C KPTR(20) - NUM BITS USED TO PACK EACH DATUM -C 2003-06-30 GILBERT ADDED GRIDS 145 and 146 for CMAQ -C and GRID 175 for AWIPS over GUAM. -C 2003-07-08 VUONG ADDED GRIDS 110, 127, 171, 172 AND MODIFIED GRID 170 -C 2004-09-02 VUONG ADDED AWIPS GRIDS 147, 148, 173 AND 254 -C 2005-01-04 COOKE ADDED AWIPS GRIDS 160 AND 161 -C 2005-03-03 VUONG MOVED GRID 170 TO GRID 174 AND ADD GRID 170 -C 2005-03-21 VUONG ADDED AWIPS GRID 130 -C 2005-10-11 VUONG ADDED AWIPS GRID 163 -C 2006-12-12 VUONG ADDED AWIPS GRID 120 -C 2007-04-12 VUONG ADDED AWIPS 176 AND DATA REP TYPE KGDS(1) 204 -C 2007-06-11 VUONG ADDED NEW GRIDS 11 TO 18 AND 122 TO 125 AND 138 -C AND 180 TO 183 -C 2007-11-06 VUONG CHANGED GRID 198 FROM ARAKAWA STAGGERED E-GRID TO POLAR -C STEREOGRAPGIC GRID ADDED NEW GRID 10, 99, 150, 151, 197 -C 2008-01-17 VUONG ADDED NEW GRID 195 AND CHANGED GRID 196 (ARAKAWA-E TO MERCATOR) -C 2009-05-21 VUONG MODIFIED TO HANDLE GRID 45 -C 2010-05-11 VUONG DATA REP TYPE KGDS(1) 205 -C 2010-02-18 VUONG ADDED GRID 128, 139 AND 140 -C 2010-07-20 GAYNO ADDED ROTATED LAT/LON "A,B,C,D" STAGGERS -> KGDS(1) 205 -C 2010-08-05 VUONG ADDED NEW GRID 184, 199, 83 AND -C REDEFINED GRID 90 FOR NEW RTMA CONUS 1.27-KM -C REDEFINED GRID 91 FOR NEW RTMA ALASKA 2.976-KM -C REDEFINED GRID 92 FOR NEW RTMA ALASKA 1.488-KM -C 2010-09-08 ROGERS CHANGED GRID 94 TO ALASKA 6KM STAGGERED B-GRID -C CHANGED GRID 95 TO PUERTO RICO 3KM STAGGERED B-GRID -C CHANGED GRID 96 TO HAWAII 3KM STAGGERED B-GRID -C CHANGED GRID 96 TO HAWAII 3KM STAGGERED B-GRID -C CHANGED GRID 97 TO CONUS 4KM STAGGERED B-GRID -C CHANGED GRID 99 TO NAM 12KM STAGGERED B-GRID -C ADDED GRID 179 (12 KM POLAR STEREOGRAPHIC OVER NORTH AMERICA) -C CHANGED GRID 194 TO 3KM MERCATOR GRID OVER PUERTO RICO -C CORRECTED LATITUDE OF SW CORNER POINT OF GRID 151 -C 2011-10-12 VUONG ADDED GRID 129, 187, 188, 189 AND 193 -C 2012-04-16 VUONG ADDED NEW GRID 132, 200 -C -C USAGE: CALL W3FI63(MSGA,KPDS,KGDS,KBMS,DATA,KPTR,KRET) -C INPUT ARGUMENT LIST: -C MSGA - GRIB FIELD - "GRIB" THRU "7777" CHAR*1 -C (MESSAGE CAN BE PRECEDED BY JUNK CHARS) -C -C OUTPUT ARGUMENT LIST: -C DATA - ARRAY CONTAINING DATA ELEMENTS -C KPDS - ARRAY CONTAINING PDS ELEMENTS. (EDITION 1) -C (1) - ID OF CENTER -C (2) - GENERATING PROCESS ID NUMBER -C (3) - GRID DEFINITION -C (4) - GDS/BMS FLAG (RIGHT ADJ COPY OF OCTET 8) -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR INCLUDING (CENTURY-1) -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - VERSION NR OF GRIB SPECIFICATION -C (19) - VERSION NR OF PARAMETER TABLE -C (20) - NR MISSING FROM AVERAGE/ACCUMULATION -C (21) - CENTURY OF REFERENCE TIME OF DATA -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER NUMBER -C (24) - PDS BYTE 29, FOR NMC ENSEMBLE PRODUCTS -C 128 IF FORECAST FIELD ERROR -C 64 IF BIAS CORRECTED FCST FIELD -C 32 IF SMOOTHED FIELD -C WARNING: CAN BE COMBINATION OF MORE THAN 1 -C (25) - PDS BYTE 30, NOT USED -C (26-35) - RESERVED -C (36-N) - CONSECUTIVE BYTES EXTRACTED FROM PROGRAM -C DEFINITION SECTION (PDS) OF GRIB MESSAGE -C KGDS - ARRAY CONTAINING GDS ELEMENTS. -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C GAUSSIAN GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - N - NR OF CIRCLES POLE TO EQUATOR -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - NV - NR OF VERT COORD PARAMETERS -C (13) - PV - OCTET NR OF LIST OF VERT COORD PARAMETERS -C OR -C PL - LOCATION OF THE LIST OF NUMBERS OF POINTS IN -C EACH ROW (IF NO VERT COORD PARAMETERS -C ARE PRESENT -C OR -C 255 IF NEITHER ARE PRESENT -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE (RIGHT ADJ COPY OF OCTET 28) -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIT - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C E-STAGGERED ARAKAWA ROTATED LAT/LON GRIDS (TYPE 203) -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF CENTER -C (8) - LO(2) LONGITUDE OF CENTER -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C CURVILINEAR ORTHIGINAL GRID (TYPE 204) -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - RESERVED SET TO 0 -C (5) - RESERVED SET TO 0 -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - RESERVED SET TO 0 -C (8) - RESERVED SET TO 0 -C (9) - RESERVED SET TO 0 -C (10) - RESERVED SET TO 0 -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C ROTATED LAT/LON A,B,C,D-STAGGERED (TYPE 205) -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF FIRST POINT -C (5) - LO(1) LONGITUDE OF FIRST POINT -C (6) - RESOLUTION FLAG (RIGHT ADJ COPY OF OCTET 17) -C (7) - LA(2) LATITUDE OF CENTER -C (8) - LO(2) LONGITUDE OF CENTER -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG (RIGHT ADJ COPY OF OCTET 28) -C (12) - LATITUDE OF LAST POINT -C (13) - LONGITUDE OF LAST POINT -C KBMS - BITMAP DESCRIBING LOCATION OF OUTPUT ELEMENTS. -C (ALWAYS CONSTRUCTED) -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - TOTAL LENGTH OF GRIB MESSAGE -C (2) - LENGTH OF INDICATOR (SECTION 0) -C (3) - LENGTH OF PDS (SECTION 1) -C (4) - LENGTH OF GDS (SECTION 2) -C (5) - LENGTH OF BMS (SECTION 3) -C (6) - LENGTH OF BDS (SECTION 4) -C (7) - VALUE OF CURRENT BYTE -C (8) - BIT POINTER -C (9) - GRIB START BIT NR -C (10) - GRIB/GRID ELEMENT COUNT -C (11) - NR UNUSED BITS AT END OF SECTION 3 -C (12) - BIT MAP FLAG (COPY OF BMS OCTETS 5,6) -C (13) - NR UNUSED BITS AT END OF SECTION 2 -C (14) - BDS FLAGS (RIGHT ADJ COPY OF OCTET 4) -C (15) - NR UNUSED BITS AT END OF SECTION 4 -C (16) - RESERVED -C (17) - RESERVED -C (18) - RESERVED -C (19) - BINARY SCALE FACTOR -C (20) - NUM BITS USED TO PACK EACH DATUM -C KRET - FLAG INDICATING QUALITY OF COMPLETION -C -C REMARKS: WHEN DECODING IS COMPLETED, DATA AT EACH GRID POINT HAS BEEN -C RETURNED IN THE UNITS SPECIFIED IN THE GRIB MANUAL. -C -C VALUES FOR RETURN FLAG (KRET) -C KRET = 0 - NORMAL RETURN, NO ERRORS -C = 1 - 'GRIB' NOT FOUND IN FIRST 100 CHARS -C = 2 - '7777' NOT IN CORRECT LOCATION -C = 3 - UNPACKED FIELD IS LARGER THAN 260000 -C = 4 - GDS/ GRID NOT ONE OF CURRENTLY ACCEPTED VALUES -C = 5 - GRID NOT CURRENTLY AVAIL FOR CENTER INDICATED -C = 8 - TEMP GDS INDICATED, BUT GDS FLAG IS OFF -C = 9 - GDS INDICATES SIZE MISMATCH WITH STD GRID -C =10 - INCORRECT CENTER INDICATOR -C =11 - BINARY DATA SECTION (BDS) NOT COMPLETELY PROCESSED. -C PROGRAM IS NOT SET TO PROCESS FLAG COMBINATIONS -C SHOWN IN OCTETS 4 AND 14. -C =12 - BINARY DATA SECTION (BDS) NOT COMPLETELY PROCESSED. -C PROGRAM IS NOT SET TO PROCESS FLAG COMBINATIONS -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -C 4 AUG 1988 -C W3FI63 -C -C -C GRIB UNPACKING ROUTINE -C -C -C THIS ROUTINE WILL UNPACK A 'GRIB' FIELD TO THE EXACT GRID -C TYPE SPECIFIED IN THE MESSAGE, RETURN A BIT MAP AND MAKE THE -C VALUES OF THE PRODUCT DEFINITION SEC (PDS) AND THE GRID -C DESCRIPTION SEC (GDS) AVAILABLE IN RETURN ARRAYS. -C SEE "GRIB - THE WMO FORMAT FOR THE STORAGE OF WEATHER PRODUCT -C INFORMATION AND THE EXCHANGE OF WEATHER PRODUCT MESSAGES IN -C GRIDDED BINARY FORM" DATED JULY 1, 1988 BY JOHN D. STACKPOLE -C DOC, NOAA, NWS, NATIONAL METEOROLOGICAL CENTER. -C -C THE CALL TO THE GRIB UNPACKING ROUTINE IS AS FOLLOWS: -C -C CALL W3FI63(MSGA,KPDS,KGDS,LBMS,DATA,KPTR,KRET) -C -C INPUT: -C -C MSGA = CONTAINS THE GRIB MESSAGE TO BE UNPACKED. CHARACTERS -C "GRIB" MAY BEGIN ANYWHERE WITHIN FIRST 100 BYTES. -C -C OUTPUT: -C -C KPDS(100) INTEGER*4 -C ARRAY TO CONTAIN THE ELEMENTS OF THE PRODUCT -C DEFINITION SEC . -C (VERSION 1) -C KPDS(1) - ID OF CENTER -C KPDS(2) - MODEL IDENTIFICATION (SEE "GRIB" TABLE 1) -C KPDS(3) - GRID IDENTIFICATION (SEE "GRIB" TABLE 2) -C KPDS(4) - GDS/BMS FLAG -C BIT DEFINITION -C 25 0 - GDS OMITTED -C 1 - GDS INCLUDED -C 26 0 - BMS OMITTED -C 1 - BMS INCLUDED -C NOTE:- LEFTMOST BIT = 1, -C RIGHTMOST BIT = 32 -C KPDS(5) - INDICATOR OF PARAMETER (SEE "GRIB" TABLE 5) -C KPDS(6) - TYPE OF LEVEL (SEE "GRIB" TABLES 6 & 7) -C KPDS(7) - HEIGHT,PRESSURE,ETC OF LEVEL -C KPDS(8) - YEAR INCLUDING CENTURY -C KPDS(9) - MONTH OF YEAR -C KPDS(10) - DAY OF MONTH -C KPDS(11) - HOUR OF DAY -C KPDS(12) - MINUTE OF HOUR -C KPDS(13) - INDICATOR OF FORECAST TIME UNIT (SEE "GRIB" -C TABLE 8) -C KPDS(14) - TIME 1 (SEE "GRIB" TABLE 8A) -C KPDS(15) - TIME 2 (SEE "GRIB" TABLE 8A) -C KPDS(16) - TIME RANGE INDICATOR (SEE "GRIB" TABLE 8A) -C KPDS(17) - NUMBER INCLUDED IN AVERAGE -C KPDS(18) - EDITION NR OF GRIB SPECIFICATION -C KPDS(19) - VERSION NR OF PARAMETER TABLE -C -C KGDS(13) INTEGER*4 -C ARRAY CONTAINING GDS ELEMENTS. -C -C KGDS(1) - DATA REPRESENTATION TYPE -C -C LATITUDE/LONGITUDE GRIDS (SEE "GRIB" TABLE 10) -C KGDS(2) - N(I) NUMBER OF POINTS ON LATITUDE -C CIRCLE -C KGDS(3) - N(J) NUMBER OF POINTS ON LONGITUDE -C CIRCLE -C KGDS(4) - LA(1) LATITUDE OF ORIGIN -C KGDS(5) - LO(1) LONGITUDE OF ORIGIN -C KGDS(6) - RESOLUTION FLAG -C BIT MEANING -C 25 0 - DIRECTION INCREMENTS NOT -C GIVEN -C 1 - DIRECTION INCREMENTS GIVEN -C KGDS(7) - LA(2) LATITUDE OF EXTREME POINT -C KGDS(8) - LO(2) LONGITUDE OF EXTREME POINT -C KGDS(9) - DI LONGITUDINAL DIRECTION INCREMENT -C KGDS(10) - REGULAR LAT/LON GRID -C DJ - LATITUDINAL DIRECTION -C INCREMENT -C GAUSSIAN GRID -C N - NUMBER OF LATITUDE CIRCLES -C BETWEEN A POLE AND THE EQUATOR -C KGDS(11) - SCANNING MODE FLAG -C BIT MEANING -C 25 0 - POINTS ALONG A LATITUDE -C SCAN FROM WEST TO EAST -C 1 - POINTS ALONG A LATITUDE -C SCAN FROM EAST TO WEST -C 26 0 - POINTS ALONG A MERIDIAN -C SCAN FROM NORTH TO SOUTH -C 1 - POINTS ALONG A MERIDIAN -C SCAN FROM SOUTH TO NORTH -C 27 0 - POINTS SCAN FIRST ALONG -C CIRCLES OF LATITUDE, THEN -C ALONG MERIDIANS -C (FORTRAN: (I,J)) -C 1 - POINTS SCAN FIRST ALONG -C MERIDIANS THEN ALONG -C CIRCLES OF LATITUDE -C (FORTRAN: (J,I)) -C -C POLAR STEREOGRAPHIC GRIDS (SEE GRIB TABLE 12) -C KGDS(2) - N(I) NR POINTS ALONG LAT CIRCLE -C KGDS(3) - N(J) NR POINTS ALONG LON CIRCLE -C KGDS(4) - LA(1) LATITUDE OF ORIGIN -C KGDS(5) - LO(1) LONGITUDE OF ORIGIN -C KGDS(6) - RESERVED -C KGDS(7) - LOV GRID ORIENTATION -C KGDS(8) - DX - X DIRECTION INCREMENT -C KGDS(9) - DY - Y DIRECTION INCREMENT -C KGDS(10) - PROJECTION CENTER FLAG -C KGDS(11) - SCANNING MODE -C -C SPHERICAL HARMONIC COEFFICIENTS (SEE "GRIB" TABLE 14) -C KGDS(2) - J PENTAGONAL RESOLUTION PARAMETER -C KGDS(3) - K PENTAGONAL RESOLUTION PARAMETER -C KGDS(4) - M PENTAGONAL RESOLUTION PARAMETER -C KGDS(5) - REPRESENTATION TYPE -C KGDS(6) - COEFFICIENT STORAGE MODE -C -C MERCATOR GRIDS -C KGDS(2) - N(I) NR POINTS ON LATITUDE CIRCLE -C KGDS(3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C KGDS(4) - LA(1) LATITUDE OF ORIGIN -C KGDS(5) - LO(1) LONGITUDE OF ORIGIN -C KGDS(6) - RESOLUTION FLAG -C KGDS(7) - LA(2) LATITUDE OF LAST GRID POINT -C KGDS(8) - LO(2) LONGITUDE OF LAST GRID POINT -C KGDS(9) - LATIN - LATITUDE OF PROJECTION INTERSECTION -C KGDS(10) - RESERVED -C KGDS(11) - SCANNING MODE FLAG -C KGDS(12) - LONGITUDINAL DIR GRID LENGTH -C KGDS(13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C KGDS(2) - NX NR POINTS ALONG X-AXIS -C KGDS(3) - NY NR POINTS ALONG Y-AXIS -C KGDS(4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C KGDS(5) - LO1 LON OF ORIGIN (LOWER LEFT) -C KGDS(6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C KGDS(7) - LOV - ORIENTATION OF GRID -C KGDS(8) - DX - X-DIR INCREMENT -C KGDS(9) - DY - Y-DIR INCREMENT -C KGDS(10) - PROJECTION CENTER FLAG -C KGDS(11) - SCANNING MODE FLAG -C KGDS(12) - LATIN 1 - FIRST LAT FROM POLE OF -C SECANT CONE INTERSECTION -C KGDS(13) - LATIN 2 - SECOND LAT FROM POLE OF -C SECANT CONE INTERSECTION -C -C LBMS(*) LOGICAL -C ARRAY TO CONTAIN THE BIT MAP DESCRIBING THE -C PLACEMENT OF DATA IN THE OUTPUT ARRAY. IF A -C BIT MAP IS NOT INCLUDED IN THE SOURCE MESSAGE, -C ONE WILL BE GENERATED AUTOMATICALLY BY THE -C UNPACKING ROUTINE. -C -C -C DATA(*) REAL*4 -C THIS ARRAY WILL CONTAIN THE UNPACKED DATA POINTS. -C -C NOTE:- 65160 IS MAXIMUN FIELD SIZE ALLOWABLE -C -C KPTR(10) INTEGER*4 -C ARRAY CONTAINING STORAGE FOR THE FOLLOWING -C PARAMETERS. -C -C (1) - UNUSED -C (2) - UNUSED -C (3) - LENGTH OF PDS (IN BYTES) -C (4) - LENGTH OF GDS (IN BYTES) -C (5) - LENGTH OF BMS (IN BYTES) -C (6) - LENGTH OF BDS (IN BYTES) -C (7) - USED BY UNPACKING ROUTINE -C (8) - NUMBER OF DATA POINTS FOR GRID -C (9) - "GRIB" CHARACTERS START IN BYTE NUMBER -C (10) - USED BY UNPACKING ROUTINE -C -C -C KRET INTEGER*4 -C THIS VARIABLE WILL CONTAIN THE RETURN INDICATOR. -C -C 0 - NO ERRORS DETECTED. -C -C 1 - 'GRIB' NOT FOUND IN FIRST 100 -C CHARACTERS. -C -C 2 - '7777' NOT FOUND, EITHER MISSING OR -C TOTAL OF SEC COUNTS OF INDIVIDUAL -C SECTIONS IS INCORRECT. -C -C 3 - UNPACKED FIELD IS LARGER THAN 65160. -C -C 4 - IN GDS, DATA REPRESENTATION TYPE -C NOT ONE OF THE CURRENTLY ACCEPTABLE -C VALUES. SEE "GRIB" TABLE 9. VALUE -C OF INCORRECT TYPE RETURNED IN KGDS(1). -C -C 5 - GRID INDICATED IN KPDS(3) IS NOT -C AVAILABLE FOR THE CENTER INDICATED IN -C KPDS(1) AND NO GDS SENT. -C -C 7 - EDITION INDICATED IN KPDS(18) HAS NOT -C YET BEEN INCLUDED IN THE DECODER. -C -C 8 - GRID IDENTIFICATION = 255 (NOT STANDARD -C GRID) BUT FLAG INDICATING PRESENCE OF -C GDS IS TURNED OFF. NO METHOD OF -C GENERATING PROPER GRID. -C -C 9 - PRODUCT OF KGDS(2) AND KGDS(3) DOES NOT -C MATCH STANDARD NUMBER OF POINTS FOR THIS -C GRID (FOR OTHER THAN SPECTRALS). THIS -C WILL OCCUR ONLY IF THE GRID. -C IDENTIFICATION, KPDS(3), AND A -C TRANSMITTED GDS ARE INCONSISTENT. -C -C 10 - CENTER INDICATOR WAS NOT ONE INDICATED -C IN "GRIB" TABLE 1. PLEASE CONTACT AD -C PRODUCTION MANAGEMENT BRANCH (W/NMC42) -C IF THIS ERROR IS ENCOUNTERED. -C -C 11 - BINARY DATA SECTION (BDS) NOT COMPLETELY -C PROCESSED. PROGRAM IS NOT SET TO PROCESS -C FLAG COMBINATIONS AS SHOWN IN -C OCTETS 4 AND 14. -C -C -C LIST OF TEXT MESSAGES FROM CODE -C -C -C W3FI63/FI632 -C -C 'HAVE ENCOUNTERED A NEW GRID FOR NMC, PLEASE NOTIFY -C AUTOMATION DIVISION, PRODUCTION MANAGEMENT BRANCH -C (W/NMC42)' -C -C 'HAVE ENCOUNTERED A NEW GRID FOR ECMWF, PLEASE NOTIFY -C AUTOMATION DIVISION, PRODUCTION MANAGEMENT BRANCH -C (W/NMC42)' -C -C 'HAVE ENCOUNTERED A NEW GRID FOR U.K. METEOROLOGICAL -C OFFICE, BRACKNELL. PLEASE NOTIFY AUTOMATION DIVISION, -C PRODUCTION MANAGEMENT BRANCH (W/NMC42)' -C -C 'HAVE ENCOUNTERED A NEW GRID FOR FNOC, PLEASE NOTIFY -C AUTOMATION DIVISION, PRODUCTION MANAGEMENT BRANCH -C (W/NMC42)' -C -C -C W3FI63/FI633 -C -C 'POLAR STEREO PROCESSING NOT AVAILABLE' * -C -C W3FI63/FI634 -C -C 'WARNING - BIT MAP MAY NOT BE ASSOCIATED WITH SPHERICAL -C COEFFICIENTS' -C -C -C W3FI63/FI637 -C -C 'NO CURRENT LISTING OF FNOC GRIDS' * -C -C -C * WILL BE AVAILABLE IN NEXT UPDATE -C *************************************************************** -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C BIT MAP - LOGICAL*1 KBMS(*) -C -C ELEMENTS OF PRODUCT DESCRIPTION SEC (PDS) - INTEGER KPDS(*) -C ELEMENTS OF GRID DESCRIPTION SEC (PDS) - INTEGER KGDS(*) -C -C CONTAINER FOR GRIB GRID - REAL DATA(*) -C -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C -C ***************************************************************** - INTEGER JSGN,JEXP,IFR,NPTS - REAL REALKK,FVAL1,FDIFF1 -C ***************************************************************** -C 1.0 LOCATE BEGINNING OF 'GRIB' MESSAGE -C FIND 'GRIB' CHARACTERS -C 2.0 USE COUNTS IN EACH DESCRIPTION SEC TO DETERMINE -C IF '7777' IS IN PROPER PLACE. -C 3.0 PARSE PRODUCT DEFINITION SECTION. -C 4.0 PARSE GRID DESCRIPTION SEC (IF INCLUDED) -C 5.0 PARSE BIT MAP SEC (IF INCLUDED) -C 6.0 USING INFORMATION FROM PRODUCT DEFINITION, GRID -C DESCRIPTION, AND BIT MAP SECTIONS.. EXTRACT -C DATA AND PLACE INTO PROPER ARRAY. -C ******************************************************************* -C -C MAIN DRIVER -C -C ******************************************************************* - KPTR(10) = 0 -C SEE IF PROPER 'GRIB' KEY EXISTS, THEN -C USING SEC COUNTS, DETERMINE IF '7777' -C IS IN THE PROPER LOCATION -C - CALL FI631(MSGA,KPTR,KPDS,KRET) - IF(KRET.NE.0) THEN - GO TO 900 - END IF -C PRINT *,'FI631 KPTR',(KPTR(I),I=1,16) -C -C PARSE PARAMETERS FROM PRODUCT DESCRIPTION SECTION -C - CALL FI632(MSGA,KPTR,KPDS,KRET) - IF(KRET.NE.0) THEN - GO TO 900 - END IF -C PRINT *,'FI632 KPTR',(KPTR(I),I=1,16) -C -C IF AVAILABLE, EXTRACT NEW GRID DESCRIPTION -C - IF (IAND(KPDS(4),128).NE.0) THEN - CALL FI633(MSGA,KPTR,KGDS,KRET) - IF(KRET.NE.0) THEN - GO TO 900 - END IF -C PRINT *,'FI633 KPTR',(KPTR(I),I=1,16) - END IF -C -C EXTRACT OR GENERATE BIT MAP -C - CALL FI634(MSGA,KPTR,KPDS,KGDS,KBMS,KRET) - IF (KRET.NE.0) THEN - IF (KRET.NE.9) THEN - GO TO 900 - END IF - END IF -C PRINT *,'FI634 KPTR',(KPTR(I),I=1,16) -C -C USING INFORMATION FROM PDS, BMS AND BIT DATA SEC , -C EXTRACT AND SAVE IN GRIB GRID, ALL DATA ENTRIES. -C - IF (KPDS(18).EQ.1) THEN - CALL FI635(MSGA,KPTR,KPDS,KGDS,KBMS,DATA,KRET) - IF (KPTR(3).EQ.50) THEN -C -C PDS EQUAL 50 BYTES -C THEREFORE SOMETHING SPECIAL IS GOING ON -C -C IN THIS CASE 2ND DIFFERENCE PACKING -C NEEDS TO BE UNDONE. -C -C EXTRACT FIRST VALUE FROM BYTE 41-44 PDS -C KPTR(9) CONTAINS OFFSET TO START OF -C GRIB MESSAGE. -C EXTRACT FIRST FIRST-DIFFERENCE FROM BYTES 45-48 PDS -C -C AND EXTRACT SCALE FACTOR (E) TO UNDO 2**E -C THAT WAS APPLIED PRIOR TO 2ND ORDER PACKING -C AND PLACED IN PDS BYTES 49-51 -C FACTOR IS A SIGNED TWO BYTE INTEGER -C -C ALSO NEED THE DECIMAL SCALING FROM PDS(27-28) -C (AVAILABLE IN KPDS(22) FROM UNPACKER) -C TO UNDO THE DECIMAL SCALING APPLIED TO THE -C SECOND DIFFERENCES DURING UNPACKING. -C SECOND DIFFS ALWAYS PACKED WITH 0 DECIMAL SCALE -C BUT UNPACKER DOESNT KNOW THAT. -C -C CALL GBYTE (MSGA,FVAL1,KPTR(9)+384,32) -C -C NOTE INTEGERS, CHARACTERS AND EQUIVALENCES -C DEFINED ABOVE TO MAKE THIS KKK EXTRACTION -C WORK AND LINE UP ON WORD BOUNDARIES -C -C THE NEXT CODE WILL CONVERT THE IBM370 FOATING POINT -C TO THE FLOATING POINT USED ON YOUR MACHINE. -C - call gbytec(MSGA,JSGN,KPTR(9)+384,1) - call gbytec(MSGA,JEXP,KPTR(9)+385,7) - call gbytec(MSGA,IFR,KPTR(9)+392,24) -C - IF (IFR.EQ.0) THEN - REALKK = 0.0 - ELSE IF (JEXP.EQ.0.AND.IFR.EQ.0) THEN - REALKK = 0.0 - ELSE - REALKK = FLOAT(IFR) * 16.0 ** (JEXP - 64 - 6) - IF (JSGN.NE.0) REALKK = -REALKK - END IF - FVAL1 = REALKK -C -C CALL GBYTE (MSGA,FDIFF1,KPTR(9)+416,32) -C (REPLACED BY FOLLOWING EXTRACTION) -C -C THE NEXT CODE WILL CONVERT THE IBM370 FOATING POINT -C TO THE FLOATING POINT USED ON YOUR MACHINE. -C - call gbytec(MSGA,JSGN,KPTR(9)+416,1) - call gbytec(MSGA,JEXP,KPTR(9)+417,7) - call gbytec(MSGA,IFR,KPTR(9)+424,24) -C - IF (IFR.EQ.0) THEN - REALKK = 0.0 - ELSE IF (JEXP.EQ.0.AND.IFR.EQ.0) THEN - REALKK = 0.0 - ELSE - REALKK = FLOAT(IFR) * 16.0 ** (JEXP - 64 - 6) - IF (JSGN.NE.0) REALKK = -REALKK - END IF - FDIFF1 = REALKK -C - CALL GBYTEC (MSGA,ISIGN,KPTR(9)+448,1) - CALL GBYTEC (MSGA,ISCAL2,KPTR(9)+449,15) - IF(ISIGN.GT.0) THEN - ISCAL2 = - ISCAL2 - ENDIF -C PRINT *,'DELTA POINT 1-',FVAL1 -C PRINT *,'DELTA POINT 2-',FDIFF1 -C PRINT *,'DELTA POINT 3-',ISCAL2 - NPTS = KPTR(10) -C WRITE (6,FMT='('' 2ND DIFF POINTS IN FIELD = '',/, -C & 10(3X,10F12.2,/))') (DATA(I),I=1,NPTS) -C PRINT *,'DELTA POINT 4-',KPDS(22) - CALL W3FI83 (DATA,NPTS,FVAL1,FDIFF1, - & ISCAL2,KPDS(22),KPDS,KGDS) -C WRITE (6,FMT='('' 2ND DIFF EXPANDED POINTS IN FIELD = '', -C & /,10(3X,10F12.2,/))') (DATA(I),I=1,NPTS) -C WRITE (6,FMT='('' END OF ARRAY IN FIELD = '',/, -C & 10(3X,10F12.2,/))') (DATA(I),I=NPTS-5,NPTS) - END IF - ELSE -C PRINT *,'FI635 NOT PROGRAMMED FOR EDITION NR',KPDS(18) - KRET = 7 - END IF -C - 900 RETURN - END - SUBROUTINE FI631(MSGA,KPTR,KPDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI631 FIND 'GRIB' CHARS & RESET POINTERS -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 91-09-13 -C -C ABSTRACT: FIND 'GRIB; CHARACTERS AND SET POINTERS TO THE NEXT -C BYTE FOLLOWING 'GRIB'. IF THEY EXIST EXTRACT COUNTS FROM GDS AND -C BMS. EXTRACT COUNT FROM BDS. DETERMINE IF SUM OF COUNTS ACTUALLY -C PLACES TERMINATOR '7777' AT THE CORRECT LOCATION. -C -C PROGRAM HISTORY LOG: -C 91-09-13 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL FI631(MSGA,KPTR,KPDS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - GRIB FIELD - "GRIB" THRU "7777" -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - TOTAL LENGTH OF GRIB MESSAGE -C (2) - LENGTH OF INDICATOR (SECTION 0) -C (3) - LENGTH OF PDS (SECTION 1) -C (4) - LENGTH OF GDS (SECTION 2) -C (5) - LENGTH OF BMS (SECTION 3) -C (6) - LENGTH OF BDS (SECTION 4) -C (7) - VALUE OF CURRENT BYTE -C (8) - BIT POINTER -C (9) - GRIB START BIT NR -C (10) - GRIB/GRID ELEMENT COUNT -C (11) - NR UNUSED BITS AT END OF SECTION 3 -C (12) - BIT MAP FLAG -C (13) - NR UNUSED BITS AT END OF SECTION 2 -C (14) - BDS FLAGS -C (15) - NR UNUSED BITS AT END OF SECTION 4 -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR OF CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C KPTR - SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C ERROR RETURNS -C KRET = 1 - NO 'GRIB' -C 2 - NO '7777' OR MISLOCATED (BY COUNTS) -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS9000 -C -C$$$ -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C PRODUCT DESCRIPTION SECTION DATA. - INTEGER KPDS(*) -C - INTEGER KRET -C -C ****************************************************************** - KRET = 0 -C ------------------- FIND 'GRIB' KEY - DO 50 I = 0, 839, 8 - CALL GBYTEC (MSGA,MGRIB,I,32) - IF (MGRIB.EQ.1196575042) THEN - KPTR(9) = I - GO TO 60 - END IF - 50 CONTINUE - KRET = 1 - RETURN - 60 CONTINUE -C -------------FOUND 'GRIB' -C SKIP GRIB CHARACTERS -C PRINT *,'FI631 GRIB AT',I - KPTR(8) = KPTR(9) + 32 - CALL GBYTEC (MSGA,ITOTAL,KPTR(8),24) -C HAVE LIFTED WHAT MAY BE A MSG TOTAL BYTE COUNT - IPOINT = KPTR(9) + ITOTAL * 8 - 32 - CALL GBYTEC (MSGA,I7777,IPOINT,32) - IF (I7777.EQ.926365495) THEN -C HAVE FOUND END OF MESSAGE '7777' IN PROPER LOCATION -C MARK AND PROCESS AS GRIB VERSION 1 OR HIGHER -C PRINT *,'FI631 7777 AT',IPOINT - KPTR(8) = KPTR(8) + 24 - KPTR(1) = ITOTAL - KPTR(2) = 8 - CALL GBYTEC (MSGA,KPDS(18),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 - ELSE -C CANNOT FIND END OF GRIB EDITION 1 MESSAGE - KRET = 2 - RETURN - END IF -C ------------------- PROCESS SECTION 1 -C EXTRACT COUNT FROM PDS -C PRINT *,'START OF PDS',KPTR(8) - CALL GBYTEC (MSGA,KPTR(3),KPTR(8),24) - LOOK = KPTR(8) + 56 -C EXTRACT GDS/BMS FLAG - CALL GBYTEC (MSGA,KPDS(4),LOOK,8) - KPTR(8) = KPTR(8) + KPTR(3) * 8 -C PRINT *,'START OF GDS',KPTR(8) - IF (IAND(KPDS(4),128).NE.0) THEN -C EXTRACT COUNT FROM GDS - CALL GBYTEC (MSGA,KPTR(4),KPTR(8),24) - KPTR(8) = KPTR(8) + KPTR(4) * 8 - ELSE - KPTR(4) = 0 - END IF -C PRINT *,'START OF BMS',KPTR(8) - IF (IAND(KPDS(4),64).NE.0) THEN -C EXTRACT COUNT FROM BMS - CALL GBYTEC (MSGA,KPTR(5),KPTR(8),24) - ELSE - KPTR(5) = 0 - END IF - KPTR(8) = KPTR(8) + KPTR(5) * 8 -C PRINT *,'START OF BDS',KPTR(8) -C EXTRACT COUNT FROM BDS - CALL GBYTEC (MSGA,KPTR(6),KPTR(8),24) -C --------------- TEST FOR '7777' -C PRINT *,(KPTR(KJ),KJ=1,10) - KPTR(8) = KPTR(8) + KPTR(6) * 8 -C EXTRACT FOUR BYTES FROM THIS LOCATION -C PRINT *,'FI631 LOOKING FOR 7777 AT',KPTR(8) - CALL GBYTEC (MSGA,K7777,KPTR(8),32) - MATCH = KPTR(2) + KPTR(3) + KPTR(4) + KPTR(5) + KPTR(6) + 4 - IF (K7777.NE.926365495.OR.MATCH.NE.KPTR(1)) THEN - KRET = 2 - ELSE -C PRINT *,'FI631 7777 AT',KPTR(8) - IF (KPDS(18).EQ.0) THEN - KPTR(1) = KPTR(2) + KPTR(3) + KPTR(4) + KPTR(5) + - * KPTR(6) + 4 - END IF - END IF -C PRINT *,'KPTR',(KPTR(I),I=1,16) - RETURN - END - SUBROUTINE FI632(MSGA,KPTR,KPDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI632 GATHER INFO FROM PRODUCT DEFINITION SEC -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 91-09-13 -C -C ABSTRACT: EXTRACT INFORMATION FROM THE PRODUCT DESCRIPTION -C SEC , AND GENERATE LABEL INFORMATION TO PERMIT STORAGE -C IN OFFICE NOTE 84 FORMAT. -C -C PROGRAM HISTORY LOG: -C 91-09-13 CAVANAUGH -C 93-12-08 CAVANAUGH CORRECTED TEST FOR EDITION NUMBER INSTEAD -C OF VERSION NUMBER -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 99-01-20 BALDWIN MODIFIED TO HANDLE GRID 237 -C -C USAGE: CALL FI632(MSGA,KPTR,KPDS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - TOTAL LENGTH OF GRIB MESSAGE -C (2) - LENGTH OF INDICATOR (SECTION 0) -C (3) - LENGTH OF PDS (SECTION 1) -C (4) - LENGTH OF GDS (SECTION 2) -C (5) - LENGTH OF BMS (SECTION 3) -C (6) - LENGTH OF BDS (SECTION 4) -C (7) - VALUE OF CURRENT BYTE -C (8) - BIT POINTER -C (9) - GRIB START BIT NR -C (10) - GRIB/GRID ELEMENT COUNT -C (11) - NR UNUSED BITS AT END OF SECTION 3 -C (12) - BIT MAP FLAG -C (13) - NR UNUSED BITS AT END OF SECTION 2 -C (14) - BDS FLAGS -C (15) - NR UNUSED BITS AT END OF SECTION 4 -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR OF CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C (18) - -C (19) - -C (20) - NUMBER MISSING FROM AVGS/ACCUMULATIONS -C (21) - CENTURY -C (22) - UNITS DECIMAL SCALE FACTOR -C (23) - SUBCENTER -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C ERROR RETURN = 0 - NO ERRORS -C = 8 - TEMP GDS INDICATED, BUT NO GDS -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS9000 -C -C$$$ -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C PRODUCT DESCRIPTION SECTION ENTRIES - INTEGER KPDS(*) -C - INTEGER KRET - KRET=0 -C ------------------- PROCESS SECTION 1 - KPTR(8) = KPTR(9) + KPTR(2) * 8 + 24 -C BYTE 4 -C PARAMETER TABLE VERSION NR - CALL GBYTEC (MSGA,KPDS(19),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 5 IDENTIFICATION OF CENTER - CALL GBYTEC (MSGA,KPDS(1),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 6 -C GET GENERATING PROCESS ID NR - CALL GBYTEC (MSGA,KPDS(2),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 7 -C GRID DEFINITION - CALL GBYTEC (MSGA,KPDS(3),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 8 -C GDS/BMS FLAGS -C CALL GBYTEC (MSGA,KPDS(4),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 9 -C INDICATOR OF PARAMETER - CALL GBYTEC (MSGA,KPDS(5),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 10 -C TYPE OF LEVEL - CALL GBYTEC (MSGA,KPDS(6),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 11,12 -C HEIGHT/PRESSURE - CALL GBYTEC (MSGA,KPDS(7),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C BYTE 13 -C YEAR OF CENTURY - CALL GBYTEC (MSGA,KPDS(8),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 14 -C MONTH OF YEAR - CALL GBYTEC (MSGA,KPDS(9),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 15 -C DAY OF MONTH - CALL GBYTEC (MSGA,KPDS(10),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 16 -C HOUR OF DAY - CALL GBYTEC (MSGA,KPDS(11),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 17 -C MINUTE - CALL GBYTEC (MSGA,KPDS(12),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 18 -C INDICATOR TIME UNIT RANGE - CALL GBYTEC (MSGA,KPDS(13),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 19 -C P1 - PERIOD OF TIME - CALL GBYTEC (MSGA,KPDS(14),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 20 -C P2 - PERIOD OF TIME - CALL GBYTEC (MSGA,KPDS(15),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 21 -C TIME RANGE INDICATOR - CALL GBYTEC (MSGA,KPDS(16),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C -C IF TIME RANGE INDICATOR IS 10, P1 IS PACKED IN -C PDS BYTES 19-20 -C - IF (KPDS(16).EQ.10) THEN - KPDS(14) = KPDS(14) * 256 + KPDS(15) - KPDS(15) = 0 - END IF -C BYTE 22,23 -C NUMBER INCLUDED IN AVERAGE - CALL GBYTEC (MSGA,KPDS(17),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C BYTE 24 -C NUMBER MISSING FROM AVERAGES/ACCUMULATIONS - CALL GBYTEC (MSGA,KPDS(20),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 25 -C IDENTIFICATION OF CENTURY - CALL GBYTEC (MSGA,KPDS(21),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 - IF (KPTR(3).GT.25) THEN -C BYTE 26 SUB CENTER NUMBER - CALL GBYTEC (MSGA,KPDS(23),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 - IF (KPTR(3).GE.28) THEN -C BYTE 27-28 -C UNITS DECIMAL SCALE FACTOR - CALL GBYTEC (MSGA,ISIGN,KPTR(8),1) - KPTR(8) = KPTR(8) + 1 - CALL GBYTEC (MSGA,IDEC,KPTR(8),15) - KPTR(8) = KPTR(8) + 15 - IF (ISIGN.GT.0) THEN - KPDS(22) = - IDEC - ELSE - KPDS(22) = IDEC - END IF - ISIZ = KPTR(3) - 28 - IF (ISIZ.LE.12) THEN -C BYTE 29 - CALL GBYTEC (MSGA,KPDS(24),KPTR(8)+8,8) -C BYTE 30 - CALL GBYTEC (MSGA,KPDS(25),KPTR(8)+16,8) -C BYTES 31-40 CURRENTLY RESERVED FOR FUTURE USE - KPTR(8) = KPTR(8) + ISIZ * 8 - ELSE -C BYTE 29 - CALL GBYTEC (MSGA,KPDS(24),KPTR(8)+8,8) -C BYTE 30 - CALL GBYTEC (MSGA,KPDS(25),KPTR(8)+16,8) -C BYTES 31-40 CURRENTLY RESERVED FOR FUTURE USE - KPTR(8) = KPTR(8) + 12 * 8 -C BYTES 41 - N LOCAL USE DATA - CALL W3FI01(LW) -C MWDBIT = LW * 8 - MWDBIT = bit_size(KPDS) - ISIZ = KPTR(3) - 40 - ITER = ISIZ / LW - IF (MOD(ISIZ,LW).NE.0) ITER = ITER + 1 - CALL GBYTESC (MSGA,KPDS(36),KPTR(8),MWDBIT,0,ITER) - KPTR(8) = KPTR(8) + ISIZ * 8 - END IF - END IF - END IF -C ----------- TEST FOR NEW GRID - IF (IAND(KPDS(4),128).NE.0) THEN - IF (IAND(KPDS(4),64).NE.0) THEN - IF (KPDS(3).NE.255) THEN - IF (KPDS(3).GE.21.AND.KPDS(3).LE.26)THEN - RETURN - ELSE IF (KPDS(3).GE.37.AND.KPDS(3).LE.44)THEN - RETURN - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - RETURN - END IF - IF (KPDS(1).EQ.7) THEN - IF (KPDS(3).GE.2.AND.KPDS(3).LE.3) THEN - ELSE IF (KPDS(3).GE.5.AND.KPDS(3).LE.6) THEN - ELSE IF (KPDS(3).EQ.8) THEN - ELSE IF (KPDS(3).EQ.10) THEN - ELSE IF (KPDS(3).GE.27.AND.KPDS(3).LE.34) THEN - ELSE IF (KPDS(3).EQ.50) THEN - ELSE IF (KPDS(3).EQ.53) THEN - ELSE IF (KPDS(3).GE.70.AND.KPDS(3).LE.77) THEN - ELSE IF (KPDS(3).EQ.98) THEN - ELSE IF (KPDS(3).EQ.99) THEN - ELSE IF (KPDS(3).GE.100.AND.KPDS(3).LE.105) THEN - ELSE IF (KPDS(3).EQ.126) THEN - ELSE IF (KPDS(3).EQ.195) THEN - ELSE IF (KPDS(3).EQ.196) THEN - ELSE IF (KPDS(3).EQ.197) THEN - ELSE IF (KPDS(3).EQ.198) THEN - ELSE IF (KPDS(3).GE.200.AND.KPDS(3).LE.237) THEN - ELSE -C PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', -C * ' NMC WITHOUT A GRID DESCRIPTION SECTION' -C PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' -C PRINT *,' PRODUCTION MANAGEMENT BRANCH' -C PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.98) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.16) THEN - ELSE -C PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', -C * ' ECMWF WITHOUT A GRID DESCRIPTION SECTION' -C PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' -C PRINT *,' PRODUCTION MANAGEMENT BRANCH' -C PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.74) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.12) THEN - ELSE IF (KPDS(3).GE.21.AND.KPDS(3).LE.26)THEN - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - ELSE IF (KPDS(3).GE.70.AND.KPDS(3).LE.77) THEN - ELSE -C PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', -C * ' U.K. MET OFFICE, BRACKNELL', -C * ' WITHOUT A GRID DESCRIPTION SECTION' -C PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' -C PRINT *,' PRODUCTION MANAGEMENT BRANCH' -C PRINT *,' W/NMC42)' - END IF - ELSE IF (KPDS(1).EQ.58) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.12) THEN - ELSE -C PRINT *,' HAVE ENCOUNTERED A NEW GRID FOR', -C * ' FNOC WITHOUT A GRID DESCRIPTION SECTION' -C PRINT *,' PLEASE NOTIFY AUTOMATION DIVISION' -C PRINT *,' PRODUCTION MANAGEMENT BRANCH' -C PRINT *,' W/NMC42)' - END IF - END IF - END IF - END IF - END IF - RETURN - END - SUBROUTINE FI633(MSGA,KPTR,KGDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI633 EXTRACT INFO FROM GRIB-GDS -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 91-09-13 -C -C ABSTRACT: EXTRACT INFORMATION ON UNLISTED GRID TO ALLOW -C CONVERSION TO OFFICE NOTE 84 FORMAT. -C -C PROGRAM HISTORY LOG: -C 91-09-13 CAVANAUGH -C 95-03-20 M.BALDWIN FI633 MODIFICATION TO GET -C DATA REP TYPES [KGDS(1)] 201 AND 202 TO WORK. -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-09-08 BALDWIN ADD DATA REP TYPE [KGDS(1)] 203 -C 07-04-24 VUONG ADD DATA REP TYPE [KGDS(1)] 204 -C 10-07-20 GAYNO ADD DATA REP TYPE [KGDS(1)] 205 -C -C -C USAGE: CALL FI633(MSGA,KPTR,KGDS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - TOTAL LENGTH OF GRIB MESSAGE -C (2) - LENGTH OF INDICATOR (SECTION 0) -C (3) - LENGTH OF PDS (SECTION 1) -C (4) - LENGTH OF GDS (SECTION 2) -C (5) - LENGTH OF BMS (SECTION 3) -C (6) - LENGTH OF BDS (SECTION 4) -C (7) - VALUE OF CURRENT BYTE -C (8) - BIT POINTER -C (9) - GRIB START BIT NR -C (10) - GRIB/GRID ELEMENT COUNT -C (11) - NR UNUSED BITS AT END OF SECTION 3 -C (12) - BIT MAP FLAG -C (13) - NR UNUSED BITS AT END OF SECTION 2 -C (14) - BDS FLAGS -C (15) - NR UNUSED BITS AT END OF SECTION 4 -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KGDS - ARRAY CONTAINING GDS ELEMENTS. -C (1) - DATA REPRESENTATION TYPE -C (19) - NUMBER OF VERTICAL COORDINATE PARAMETERS -C (20) - OCTET NUMBER OF THE LIST OF VERTICAL COORDINATE -C PARAMETERS -C OR -C OCTET NUMBER OF THE LIST OF NUMBERS OF POINTS -C IN EACH ROW -C OR -C 255 IF NEITHER ARE PRESENT -C (21) - FOR GRIDS WITH PL, NUMBER OF POINTS IN GRID -C (22) - NUMBER OF WORDS IN EACH ROW -C LATITUDE/LONGITUDE GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG -C (7) - LA(2) LATITUDE OF EXTREME POINT -C (8) - LO(2) LONGITUDE OF EXTREME POINT -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG -C POLAR STEREOGRAPHIC GRIDS -C (2) - N(I) NR POINTS ALONG LAT CIRCLE -C (3) - N(J) NR POINTS ALONG LON CIRCLE -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESERVED -C (7) - LOV GRID ORIENTATION -C (8) - DX - X DIRECTION INCREMENT -C (9) - DY - Y DIRECTION INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE -C SPHERICAL HARMONIC COEFFICIENTS -C (2) - J PENTAGONAL RESOLUTION PARAMETER -C (3) - K " " " -C (4) - M " " " -C (5) - REPRESENTATION TYPE -C (6) - COEFFICIENT STORAGE MODE -C MERCATOR GRIDS -C (2) - N(I) NR POINTS ON LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG -C (7) - LA(2) LATITUDE OF LAST GRID POINT -C (8) - LO(2) LONGITUDE OF LAST GRID POINT -C (9) - LATIN - LATITUDE OF PROJECTION INTERSECTION -C (10) - RESERVED -C (11) - SCANNING MODE FLAG -C (12) - LONGITUDINAL DIR GRID LENGTH -C (13) - LATITUDINAL DIR GRID LENGTH -C LAMBERT CONFORMAL GRIDS -C (2) - NX NR POINTS ALONG X-AXIS -C (3) - NY NR POINTS ALONG Y-AXIS -C (4) - LA1 LAT OF ORIGIN (LOWER LEFT) -C (5) - LO1 LON OF ORIGIN (LOWER LEFT) -C (6) - RESOLUTION (RIGHT ADJ COPY OF OCTET 17) -C (7) - LOV - ORIENTATION OF GRID -C (8) - DX - X-DIR INCREMENT -C (9) - DY - Y-DIR INCREMENT -C (10) - PROJECTION CENTER FLAG -C (11) - SCANNING MODE FLAG -C (12) - LATIN 1 - FIRST LAT FROM POLE OF SECANT CONE INTER -C (13) - LATIN 2 - SECOND LAT FROM POLE OF SECANT CONE INTER -C STAGGERED ARAKAWA ROTATED LAT/LON GRIDS (203 E STAGGER) -C (2) - N(I) NR POINTS ON ROTATED LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON ROTATED LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG -C (7) - LA(2) LATITUDE OF CENTER -C (8) - LO(2) LONGITUDE OF CENTER -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG -C STAGGERED ARAKAWA ROTATED LAT/LON GRIDS (205 A,B,C,D STAGGERS) -C (2) - N(I) NR POINTS ON ROTATED LATITUDE CIRCLE -C (3) - N(J) NR POINTS ON ROTATED LONGITUDE MERIDIAN -C (4) - LA(1) LATITUDE OF ORIGIN -C (5) - LO(1) LONGITUDE OF ORIGIN -C (6) - RESOLUTION FLAG -C (7) - LA(2) LATITUDE OF CENTER -C (8) - LO(2) LONGITUDE OF CENTER -C (9) - DI LONGITUDINAL DIRECTION OF INCREMENT -C (10) - DJ LATITUDINAL DIRECTION INCREMENT -C (11) - SCANNING MODE FLAG -C (12) - LATITUDE OF LAST POINT -C (13) - LONGITUDE OF LAST POINT -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C KRET = 0 -C = 4 - DATA REPRESENTATION TYPE NOT CURRENTLY ACCEPTABLE -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS9000 -C -C$$$ -C ************************************************************ -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C -C ARRAY GDS ELEMENTS - INTEGER KGDS(*) -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C - INTEGER KRET -C --------------------------------------------------------------- - KRET = 0 -C PROCESS GRID DEFINITION SECTION (IF PRESENT) -C MAKE SURE BIT POINTER IS PROPERLY SET - KPTR(8) = KPTR(9) + (KPTR(2)*8) + (KPTR(3)*8) + 24 - NSAVE = KPTR(8) - 24 -C BYTE 4 -C NV - NR OF VERT COORD PARAMETERS - CALL GBYTEC (MSGA,KGDS(19),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 5 -C PV - LOCATION - SEE FM92 MANUAL - CALL GBYTEC (MSGA,KGDS(20),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTE 6 -C DATA REPRESENTATION TYPE - CALL GBYTEC (MSGA,KGDS(1),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTES 7-32 ARE GRID DEFINITION DEPENDING ON -C DATA REPRESENTATION TYPE - IF (KGDS(1).EQ.0) THEN - GO TO 1000 - ELSE IF (KGDS(1).EQ.1) THEN - GO TO 4000 - ELSE IF (KGDS(1).EQ.2.OR.KGDS(1).EQ.5) THEN - GO TO 2000 - ELSE IF (KGDS(1).EQ.3) THEN - GO TO 5000 - ELSE IF (KGDS(1).EQ.4) THEN - GO TO 1000 -C ELSE IF (KGDS(1).EQ.10) THEN -C ELSE IF (KGDS(1).EQ.14) THEN -C ELSE IF (KGDS(1).EQ.20) THEN -C ELSE IF (KGDS(1).EQ.24) THEN -C ELSE IF (KGDS(1).EQ.30) THEN -C ELSE IF (KGDS(1).EQ.34) THEN - ELSE IF (KGDS(1).EQ.50) THEN - GO TO 3000 -C ELSE IF (KGDS(1).EQ.60) THEN -C ELSE IF (KGDS(1).EQ.70) THEN -C ELSE IF (KGDS(1).EQ.80) THEN - ELSE IF (KGDS(1).EQ.201.OR.KGDS(1).EQ.202.OR. - & KGDS(1).EQ.203.OR.KGDS(1).EQ.204.OR.KGDS(1).EQ.205) THEN - GO TO 1000 - ELSE -C MARK AS GDS/ UNKNOWN DATA REPRESENTATION TYPE - KRET = 4 - RETURN - END IF -C BYTE 33-N VERTICAL COORDINATE PARAMETERS -C ----------- -C BYTES 33-42 EXTENSIONS OF GRID DEFINITION FOR ROTATION -C OR STRETCHING OF THE COORDINATE SYSTEM OR -C LAMBERT CONFORMAL PROJECTION. -C BYTE 43-N VERTICAL COORDINATE PARAMETERS -C ----------- -C BYTES 33-52 EXTENSIONS OF GRID DEFINITION FOR STRETCHED -C AND ROTATED COORDINATE SYSTEM -C BYTE 53-N VERTICAL COORDINATE PARAMETERS -C ----------- -C ************************************************************ -C ------------------- LATITUDE/LONGITUDE GRIDS -C ------------------- ARAKAWA STAGGERED, SEMI-STAGGERED, OR FILLED -C ROTATED LAT/LON GRIDS OR CURVILINEAR ORTHIGINAL GRIDS -C -C ------------------- BYTE 7-8 NR OF POINTS ALONG LATITUDE CIRCLE - 1000 CONTINUE - CALL GBYTEC (MSGA,KGDS(2),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 9-10 NR OF POINTS ALONG LONG MERIDIAN - CALL GBYTEC (MSGA,KGDS(3),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 11-13 LATITUDE OF ORIGIN - CALL GBYTEC (MSGA,KGDS(4),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(4),8388608).NE.0) THEN - KGDS(4) = IAND(KGDS(4),8388607) * (-1) - END IF -C ------------------- BYTE 14-16 LONGITUDE OF ORIGIN - CALL GBYTEC (MSGA,KGDS(5),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(5),8388608).NE.0) THEN - KGDS(5) = - IAND(KGDS(5),8388607) - END IF -C ------------------- BYTE 17 RESOLUTION FLAG - CALL GBYTEC (MSGA,KGDS(6),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 18-20 LATITUDE OF LAST GRID POINT - CALL GBYTEC (MSGA,KGDS(7),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(7),8388608).NE.0) THEN - KGDS(7) = - IAND(KGDS(7),8388607) - END IF -C ------------------- BYTE 21-23 LONGITUDE OF LAST GRID POINT - CALL GBYTEC (MSGA,KGDS(8),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(8),8388608).NE.0) THEN - KGDS(8) = - IAND(KGDS(8),8388607) - END IF -C ------------------- BYTE 24-25 LATITUDINAL DIR INCREMENT - CALL GBYTEC (MSGA,KGDS(9),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 26-27 IF REGULAR LAT/LON GRID -C HAVE LONGIT DIR INCREMENT -C ELSE IF GAUSSIAN GRID -C HAVE NR OF LAT CIRCLES -C BETWEEN POLE AND EQUATOR - CALL GBYTEC (MSGA,KGDS(10),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 28 SCANNING MODE FLAGS - CALL GBYTEC (MSGA,KGDS(11),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 - IF(KGDS(1).EQ.205)THEN -C ------------------- BYTE 29-31 LATITUDE OF LAST GRID POINT - CALL GBYTEC (MSGA,KGDS(12),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(12),8388608).NE.0) THEN - KGDS(12) = - IAND(KGDS(12),8388607) - END IF -C ------------------- BYTE 32-34 LONGITUDE OF LAST GRID POINT - CALL GBYTEC (MSGA,KGDS(13),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(13),8388608).NE.0) THEN - KGDS(13) = - IAND(KGDS(13),8388607) - END IF - ELSE - -C ------------------- BYTE 29-32 RESERVED -C SKIP TO START OF BYTE 33 - CALL GBYTEC (MSGA,KGDS(12),KPTR(8),32) - KPTR(8) = KPTR(8) + 32 - ENDIF -C ------------------- - GO TO 900 -C ****************************************************************** -C ' POLAR STEREO PROCESSING ' -C -C ------------------- BYTE 7-8 NR OF POINTS ALONG X=AXIS - 2000 CONTINUE - CALL GBYTEC (MSGA,KGDS(2),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 9-10 NR OF POINTS ALONG Y-AXIS - CALL GBYTEC (MSGA,KGDS(3),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 11-13 LATITUDE OF ORIGIN - CALL GBYTEC (MSGA,KGDS(4),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(4),8388608).NE.0) THEN - KGDS(4) = - IAND(KGDS(4),8388607) - END IF -C ------------------- BYTE 14-16 LONGITUDE OF ORIGIN - CALL GBYTEC (MSGA,KGDS(5),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(5),8388608).NE.0) THEN - KGDS(5) = - IAND(KGDS(5),8388607) - END IF -C ------------------- BYTE 17 RESERVED - CALL GBYTEC (MSGA,KGDS(6),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 18-20 LOV ORIENTATION OF THE GRID - CALL GBYTEC (MSGA,KGDS(7),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(7),8388608).NE.0) THEN - KGDS(7) = - IAND(KGDS(7),8388607) - END IF -C ------------------- BYTE 21-23 DX - THE X DIRECTION INCREMENT - CALL GBYTEC (MSGA,KGDS(8),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(8),8388608).NE.0) THEN - KGDS(8) = - IAND(KGDS(8),8388607) - END IF -C ------------------- BYTE 24-26 DY - THE Y DIRECTION INCREMENT - CALL GBYTEC (MSGA,KGDS(9),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(9),8388608).NE.0) THEN - KGDS(9) = - IAND(KGDS(9),8388607) - END IF -C ------------------- BYTE 27 PROJECTION CENTER FLAG - CALL GBYTEC (MSGA,KGDS(10),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 28 SCANNING MODE - CALL GBYTEC (MSGA,KGDS(11),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 29-32 RESERVED -C SKIP TO START OF BYTE 33 - CALL GBYTEC (MSGA,KGDS(12),KPTR(8),32) - KPTR(8) = KPTR(8) + 32 -C -C ------------------- - GO TO 900 -C -C ****************************************************************** -C ------------------- GRID DESCRIPTION FOR SPHERICAL HARMONIC COEFF. -C -C ------------------- BYTE 7-8 J PENTAGONAL RESOLUTION PARAMETER - 3000 CONTINUE - CALL GBYTEC (MSGA,KGDS(2),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 9-10 K PENTAGONAL RESOLUTION PARAMETER - CALL GBYTEC (MSGA,KGDS(3),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 11-12 M PENTAGONAL RESOLUTION PARAMETER - CALL GBYTEC (MSGA,KGDS(4),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 13 REPRESENTATION TYPE - CALL GBYTEC (MSGA,KGDS(5),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 14 COEFFICIENT STORAGE MODE - CALL GBYTEC (MSGA,KGDS(6),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- EMPTY FIELDS - BYTES 15 - 32 -C SET TO START OF BYTE 33 - KPTR(8) = KPTR(8) + 18 * 8 - GO TO 900 -C ****************************************************************** -C PROCESS MERCATOR GRIDS -C -C ------------------- BYTE 7-8 NR OF POINTS ALONG LATITUDE CIRCLE - 4000 CONTINUE - CALL GBYTEC (MSGA,KGDS(2),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 9-10 NR OF POINTS ALONG LONG MERIDIAN - CALL GBYTEC (MSGA,KGDS(3),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 11-13 LATITUE OF ORIGIN - CALL GBYTEC (MSGA,KGDS(4),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(4),8388608).NE.0) THEN - KGDS(4) = - IAND(KGDS(4),8388607) - END IF -C ------------------- BYTE 14-16 LONGITUDE OF ORIGIN - CALL GBYTEC (MSGA,KGDS(5),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(5),8388608).NE.0) THEN - KGDS(5) = - IAND(KGDS(5),8388607) - END IF -C ------------------- BYTE 17 RESOLUTION FLAG - CALL GBYTEC (MSGA,KGDS(6),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 18-20 LATITUDE OF EXTREME POINT - CALL GBYTEC (MSGA,KGDS(7),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(7),8388608).NE.0) THEN - KGDS(7) = - IAND(KGDS(7),8388607) - END IF -C ------------------- BYTE 21-23 LONGITUDE OF EXTREME POINT - CALL GBYTEC (MSGA,KGDS(8),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(8),8388608).NE.0) THEN - KGDS(8) = - IAND(KGDS(8),8388607) - END IF -C ------------------- BYTE 24-26 LATITUDE OF PROJECTION INTERSECTION - CALL GBYTEC (MSGA,KGDS(9),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(9),8388608).NE.0) THEN - KGDS(9) = - IAND(KGDS(9),8388607) - END IF -C ------------------- BYTE 27 RESERVED - CALL GBYTEC (MSGA,KGDS(10),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 28 SCANNING MODE - CALL GBYTEC (MSGA,KGDS(11),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 29-31 LONGITUDINAL DIR INCREMENT - CALL GBYTEC (MSGA,KGDS(12),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(12),8388608).NE.0) THEN - KGDS(12) = - IAND(KGDS(12),8388607) - END IF -C ------------------- BYTE 32-34 LATITUDINAL DIR INCREMENT - CALL GBYTEC (MSGA,KGDS(13),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(13),8388608).NE.0) THEN - KGDS(13) = - IAND(KGDS(13),8388607) - END IF -C ------------------- BYTE 35-42 RESERVED -C SKIP TO START OF BYTE 43 - KPTR(8) = KPTR(8) + 8 * 8 -C ------------------- - GO TO 900 -C ****************************************************************** -C PROCESS LAMBERT CONFORMAL -C -C ------------------- BYTE 7-8 NR OF POINTS ALONG X-AXIS - 5000 CONTINUE - CALL GBYTEC (MSGA,KGDS(2),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 9-10 NR OF POINTS ALONG Y-AXIS - CALL GBYTEC (MSGA,KGDS(3),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- BYTE 11-13 LATITUDE OF ORIGIN - CALL GBYTEC (MSGA,KGDS(4),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(4),8388608).NE.0) THEN - KGDS(4) = - IAND(KGDS(4),8388607) - END IF -C ------------------- BYTE 14-16 LONGITUDE OF ORIGIN (LOWER LEFT) - CALL GBYTEC (MSGA,KGDS(5),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(5),8388608).NE.0) THEN - KGDS(5) = - IAND(KGDS(5),8388607) - END IF -C ------------------- BYTE 17 RESOLUTION - CALL GBYTEC (MSGA,KGDS(6),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 18-20 LOV -ORIENTATION OF GRID - CALL GBYTEC (MSGA,KGDS(7),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(7),8388608).NE.0) THEN - KGDS(7) = - IAND(KGDS(7),8388607) - END IF -C ------------------- BYTE 21-23 DX - X-DIR INCREMENT - CALL GBYTEC (MSGA,KGDS(8),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 -C ------------------- BYTE 24-26 DY - Y-DIR INCREMENT - CALL GBYTEC (MSGA,KGDS(9),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 -C ------------------- BYTE 27 PROJECTION CENTER FLAG - CALL GBYTEC (MSGA,KGDS(10),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 28 SCANNING MODE - CALL GBYTEC (MSGA,KGDS(11),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ------------------- BYTE 29-31 LATIN1 - 1ST LAT FROM POLE - CALL GBYTEC (MSGA,KGDS(12),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(12),8388608).NE.0) THEN - KGDS(12) = - IAND(KGDS(12),8388607) - END IF -C ------------------- BYTE 32-34 LATIN2 - 2ND LAT FROM POLE - CALL GBYTEC (MSGA,KGDS(13),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(13),8388608).NE.0) THEN - KGDS(13) = - IAND(KGDS(13),8388607) - END IF -C ------------------- BYTE 35-37 LATITUDE OF SOUTHERN POLE - CALL GBYTEC (MSGA,KGDS(14),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(14),8388608).NE.0) THEN - KGDS(14) = - IAND(KGDS(14),8388607) - END IF -C ------------------- BYTE 38-40 LONGITUDE OF SOUTHERN POLE - CALL GBYTEC (MSGA,KGDS(15),KPTR(8),24) - KPTR(8) = KPTR(8) + 24 - IF (IAND(KGDS(15),8388608).NE.0) THEN - KGDS(15) = - IAND(KGDS(15),8388607) - END IF -C ------------------- BYTE 41-42 RESERVED - CALL GBYTEC (MSGA,KGDS(16),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ------------------- - 900 CONTINUE -C -C MORE CODE FOR GRIDS WITH PL -C - IF (KGDS(19).EQ.0.OR.KGDS(19).EQ.255) THEN - IF (KGDS(20).NE.255) THEN - ISUM = 0 - KPTR(8) = NSAVE + (KGDS(20) - 1) * 8 - CALL GBYTESC (MSGA,KGDS(22),KPTR(8),16,0,KGDS(3)) - DO 910 J = 1, KGDS(3) - ISUM = ISUM + KGDS(21+J) - 910 CONTINUE - KGDS(21) = ISUM - END IF - END IF - RETURN - END - SUBROUTINE FI634(MSGA,KPTR,KPDS,KGDS,KBMS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI634 EXTRACT OR GENERATE BIT MAP FOR OUTPUT -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 91-09-13 -C -C ABSTRACT: IF BIT MAP SEC IS AVAILABLE IN GRIB MESSAGE, EXTRACT -C FOR PROGRAM USE, OTHERWISE GENERATE AN APPROPRIATE BIT MAP. -C -C PROGRAM HISTORY LOG: -C 91-09-13 CAVANAUGH -C 91-11-12 CAVANAUGH MODIFIED SIZE OF ECMWF GRIDS 5 - 8. -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 97-02-12 W BOSTELMAN CORRECTS ECMWF US GRID 2 PROCESSING -C 97-09-19 IREDELL VECTORIZED BITMAP DECODER -C 98-09-02 GILBERT CORRECTED ERROR IN MAP SIZE FOR U.S. GRID 92 -C 98-09-08 BALDWIN ADD GRIDS 190,192 -C 99-01-20 BALDWIN ADD GRIDS 236,237 -C 01-10-02 ROGERS REDEFINED GRID #218 FOR 12 KM ETA -C REDEFINED GRID 192 FOR NEW 32-KM ETA GRID -C 2003-06-30 GILBERT ADDED GRIDS 145 and 146 for CMAQ -C and GRID 175 for AWIPS over GUAM. -C 2004-09-02 VUONG ADDED AWIPS GRIDS 147, 148, 173 AND 254 -C 2006-12-12 VUONG ADDED AWIPS GRIDS 120 -C 2007-04-20 VUONG ADDED AWIPS GRIDS 176 -C 2007-06-11 VUONG ADDED AWIPS GRIDS 11 TO 18 AND 122 TO 125 -C AND 180 TO 183 -C 2010-08-05 VUONG ADDED NEW GRID 184, 199, 83 AND -C REDEFINED GRID 90 FOR NEW RTMA CONUS 1.27-KM -C REDEFINED GRID 91 FOR NEW RTMA ALASKA 2.976-KM -C REDEFINED GRID 92 FOR NEW RTMA ALASKA 1.488-KM -C 2012-02-28 VUONG ADDED NEW GRID 200 -C -C USAGE: CALL FI634(MSGA,KPTR,KPDS,KGDS,KBMS,KRET) -C INPUT ARGUMENT LIST: -C MSGA - BUFR MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - TOTAL LENGTH OF GRIB MESSAGE -C (2) - LENGTH OF INDICATOR (SECTION 0) -C (3) - LENGTH OF PDS (SECTION 1) -C (4) - LENGTH OF GDS (SECTION 2) -C (5) - LENGTH OF BMS (SECTION 3) -C (6) - LENGTH OF BDS (SECTION 4) -C (7) - VALUE OF CURRENT BYTE -C (8) - BIT POINTER -C (9) - GRIB START BIT NR -C (10) - GRIB/GRID ELEMENT COUNT -C (11) - NR UNUSED BITS AT END OF SECTION 3 -C (12) - BIT MAP FLAG -C (13) - NR UNUSED BITS AT END OF SECTION 2 -C (14) - BDS FLAGS -C (15) - NR UNUSED BITS AT END OF SECTION 4 -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C (1) - ID OF CENTER -C (2) - MODEL IDENTIFICATION -C (3) - GRID IDENTIFICATION -C (4) - GDS/BMS FLAG -C (5) - INDICATOR OF PARAMETER -C (6) - TYPE OF LEVEL -C (7) - HEIGHT/PRESSURE , ETC OF LEVEL -C (8) - YEAR OF CENTURY -C (9) - MONTH OF YEAR -C (10) - DAY OF MONTH -C (11) - HOUR OF DAY -C (12) - MINUTE OF HOUR -C (13) - INDICATOR OF FORECAST TIME UNIT -C (14) - TIME RANGE 1 -C (15) - TIME RANGE 2 -C (16) - TIME RANGE FLAG -C (17) - NUMBER INCLUDED IN AVERAGE -C -C OUTPUT ARGUMENT LIST: -C KBMS - BITMAP DESCRIBING LOCATION OF OUTPUT ELEMENTS. -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C KRET = 0 - NO ERROR -C = 5 - GRID NOT AVAIL FOR CENTER INDICATED -C =10 - INCORRECT CENTER INDICATOR -C =12 - BYTES 5-6 ARE NOT ZERO IN BMS, PREDEFINED BIT MAP -C NOT PROVIDED BY THIS CENTER -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS9000 -C -C$$$ -C -C INCOMING MESSAGE HOLDER - CHARACTER*1 MSGA(*) -C -C BIT MAP - LOGICAL*1 KBMS(*) -C -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPTR(*) -C ARRAY OF POINTERS AND COUNTERS - INTEGER KPDS(*) - INTEGER KGDS(*) -C - INTEGER KRET - INTEGER MASK(8) -C ----------------------GRID 21 AND GRID 22 ARE THE SAME - LOGICAL*1 GRD21( 1369) -C ----------------------GRID 23 AND GRID 24 ARE THE SAME - LOGICAL*1 GRD23( 1369) - LOGICAL*1 GRD25( 1368) - LOGICAL*1 GRD26( 1368) -C ----------------------GRID 27 AND GRID 28 ARE THE SAME -C ----------------------GRID 29 AND GRID 30 ARE THE SAME -C ----------------------GRID 33 AND GRID 34 ARE THE SAME - LOGICAL*1 GRD50( 1188) -C -----------------------GRID 61 AND GRID 62 ARE THE SAME - LOGICAL*1 GRD61( 4186) -C -----------------------GRID 63 AND GRID 64 ARE THE SAME - LOGICAL*1 GRD63( 4186) -C LOGICAL*1 GRD70(16380)/16380*.TRUE./ -C ------------------------------------------------------------- - DATA GRD21 /1333*.TRUE.,36*.FALSE./ - DATA GRD23 /.TRUE.,36*.FALSE.,1332*.TRUE./ - DATA GRD25 /1297*.TRUE.,71*.FALSE./ - DATA GRD26 /.TRUE.,71*.FALSE.,1296*.TRUE./ - DATA GRD50/ -C LINE 1-4 - & 7*.FALSE.,22*.TRUE.,14*.FALSE.,22*.TRUE., - & 14*.FALSE.,22*.TRUE.,14*.FALSE.,22*.TRUE.,7*.FALSE., -C LINE 5-8 - & 6*.FALSE.,24*.TRUE.,12*.FALSE.,24*.TRUE., - & 12*.FALSE.,24*.TRUE.,12*.FALSE.,24*.TRUE.,6*.FALSE., -C LINE 9-12 - & 5*.FALSE.,26*.TRUE.,10*.FALSE.,26*.TRUE., - & 10*.FALSE.,26*.TRUE.,10*.FALSE.,26*.TRUE.,5*.FALSE., -C LINE 13-16 - & 4*.FALSE.,28*.TRUE., 8*.FALSE.,28*.TRUE., - & 8*.FALSE.,28*.TRUE., 8*.FALSE.,28*.TRUE.,4*.FALSE., -C LINE 17-20 - & 3*.FALSE.,30*.TRUE., 6*.FALSE.,30*.TRUE., - & 6*.FALSE.,30*.TRUE., 6*.FALSE.,30*.TRUE.,3*.FALSE., -C LINE 21-24 - & 2*.FALSE.,32*.TRUE., 4*.FALSE.,32*.TRUE., - & 4*.FALSE.,32*.TRUE., 4*.FALSE.,32*.TRUE.,2*.FALSE., -C LINE 25-28 - & .FALSE.,34*.TRUE., 2*.FALSE.,34*.TRUE., - & 2*.FALSE.,34*.TRUE., 2*.FALSE.,34*.TRUE., .FALSE., -C LINE 29-33 - & 180*.TRUE./ - DATA GRD61 /4096*.TRUE.,90*.FALSE./ - DATA GRD63 /.TRUE.,90*.FALSE.,4095*.TRUE./ - DATA MASK /128,64,32,16,8,4,2,1/ -C -C PRINT *,'FI634' - IF (IAND(KPDS(4),64).EQ.64) THEN -C -C SET UP BIT POINTER -C SECTION 0 SECTION 1 SECTION 2 - KPTR(8) = KPTR(9) + (KPTR(2)*8) + (KPTR(3)*8) + (KPTR(4)*8) + 24 -C -C BYTE 4 NUMBER OF UNUSED BITS AT END OF SECTION 3 -C - CALL GBYTEC (MSGA,KPTR(11),KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C -C BYTE 5,6 TABLE REFERENCE IF 0, BIT MAP FOLLOWS -C - CALL GBYTEC (MSGA,KPTR(12),KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C IF TABLE REFERENCE = 0, EXTRACT BIT MAP - IF (KPTR(12).EQ.0) THEN -C CALCULATE NR OF BITS IN BIT MAP - IBITS = (KPTR(5) - 6) * 8 - KPTR(11) - KPTR(10) = IBITS - IF (KPDS(3).EQ.21.OR.KPDS(3).EQ.22.OR.KPDS(3).EQ.25. - * OR.KPDS(3).EQ.61.OR.KPDS(3).EQ.62) THEN -C NORTHERN HEMISPHERE 21, 22, 25, 61, 62 - CALL FI634X(IBITS,KPTR(8),MSGA,KBMS) - IF (KPDS(3).EQ.25) THEN - KADD = 71 - ELSE IF (KPDS(3).EQ.61.OR.KPDS(3).EQ.62) THEN - KADD = 90 - ELSE - KADD = 36 - END IF - DO 25 I = 1, KADD - KBMS(I+IBITS) = .FALSE. - 25 CONTINUE - KPTR(10) = KPTR(10) + KADD - RETURN - ELSE IF (KPDS(3).EQ.23.OR.KPDS(3).EQ.24.OR.KPDS(3).EQ.26. - * OR.KPDS(3).EQ.63.OR.KPDS(3).EQ.64) THEN -C SOUTHERN HEMISPHERE 23, 24, 26, 63, 64 - CALL FI634X(IBITS,KPTR(8),MSGA,KBMS) - IF (KPDS(3).EQ.26) THEN - KADD = 72 - ELSE IF (KPDS(3).EQ.63.OR.KPDS(3).EQ.64) THEN - KADD = 91 - ELSE - KADD = 37 - END IF - DO 26 I = 1, KADD - KBMS(I+IBITS) = .FALSE. - 26 CONTINUE - KPTR(10) = KPTR(10) + KADD - 1 - RETURN - ELSE IF (KPDS(3).EQ.50) THEN - KPAD = 7 - KIN = 22 - KBITS = 0 - DO 55 I = 1, 7 - DO 54 J = 1, 4 - DO 51 K = 1, KPAD - KBITS = KBITS + 1 - KBMS(KBITS) = .FALSE. - 51 CONTINUE - CALL FI634X(KIN,KPTR(8),MSGA,KBMS(KBITS+1)) - KPTR(8)=KPTR(8)+KIN - KBITS=KBITS+KIN - DO 53 K = 1, KPAD - KBITS = KBITS + 1 - KBMS(KBITS) = .FALSE. - 53 CONTINUE - 54 CONTINUE - KIN = KIN + 2 - KPAD = KPAD - 1 - 55 CONTINUE - DO 57 II = 1, 5 - CALL FI634X(KIN,KPTR(8),MSGA,KBMS(KBITS+1)) - KPTR(8)=KPTR(8)+KIN - KBITS=KBITS+KIN - 57 CONTINUE - ELSE -C EXTRACT BIT MAP FROM BMS FOR OTHER GRIDS - CALL FI634X(IBITS,KPTR(8),MSGA,KBMS) - END IF - RETURN - ELSE -C PRINT *,'FI634-NO PREDEFINED BIT MAP PROVIDED BY THIS CENTER' - KRET = 12 - RETURN - END IF -C - END IF - KRET = 0 -C ------------------------------------------------------- -C PROCESS NON-STANDARD GRID -C ------------------------------------------------------- - IF (KPDS(3).EQ.255) THEN -C PRINT *,'NON STANDARD GRID, CENTER = ',KPDS(1) - J = KGDS(2) * KGDS(3) - KPTR(10) = J - DO 600 I = 1, J - KBMS(I) = .TRUE. - 600 CONTINUE - RETURN - END IF -C ------------------------------------------------------- -C CHECK INTERNATIONAL SET -C ------------------------------------------------------- - IF (KPDS(3).EQ.21.OR.KPDS(3).EQ.22) THEN -C ----- INT'L GRIDS 21, 22 - MAP SIZE 1369 - J = 1369 - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 820 - DO 3021 I = 1, 1369 - KBMS(I) = GRD21(I) - 3021 CONTINUE - RETURN - ELSE IF (KPDS(3).EQ.23.OR.KPDS(3).EQ.24) THEN -C ----- INT'L GRIDS 23, 24 - MAP SIZE 1369 - J = 1369 - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 820 - DO 3023 I = 1, 1369 - KBMS(I) = GRD23(I) - 3023 CONTINUE - RETURN - ELSE IF (KPDS(3).EQ.25) THEN -C ----- INT'L GRID 25 - MAP SIZE 1368 - J = 1368 - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 820 - DO 3025 I = 1, 1368 - KBMS(I) = GRD25(I) - 3025 CONTINUE - RETURN - ELSE IF (KPDS(3).EQ.26) THEN -C ----- INT'L GRID 26 - MAP SIZE 1368 - J = 1368 - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 820 - DO 3026 I = 1, 1368 - KBMS(I) = GRD26(I) - 3026 CONTINUE - RETURN - ELSE IF (KPDS(3).GE.37.AND.KPDS(3).LE.44) THEN -C ----- INT'L GRID 37-44 - MAP SIZE 3447 - J = 3447 - GO TO 800 - ELSE IF (KPDS(1).EQ.7.AND.KPDS(3).EQ.50) THEN -C ----- INT'L GRIDS 50 - MAP SIZE 964 - J = 1188 - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 890 - DO 3050 I = 1, J - KBMS(I) = GRD50(I) - 3050 CONTINUE - RETURN - ELSE IF (KPDS(3).EQ.61.OR.KPDS(3).EQ.62) THEN -C ----- INT'L GRIDS 61, 62 - MAP SIZE 4186 - J = 4186 - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 820 - DO 3061 I = 1, 4186 - KBMS(I) = GRD61(I) - 3061 CONTINUE - RETURN - ELSE IF (KPDS(3).EQ.63.OR.KPDS(3).EQ.64) THEN -C ----- INT'L GRIDS 63, 64 - MAP SIZE 4186 - J = 4186 - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 820 - DO 3063 I = 1, 4186 - KBMS(I) = GRD63(I) - 3063 CONTINUE - RETURN - END IF -C ------------------------------------------------------- -C CHECK UNITED STATES SET -C ------------------------------------------------------- - IF (KPDS(1).EQ.7) THEN - IF (KPDS(3).LT.100) THEN - IF (KPDS(3).EQ.1) THEN -C ----- U.S. GRID 1 - MAP SIZE 1679 - J = 1679 - GO TO 800 - END IF - IF (KPDS(3).EQ.2) THEN -C ----- U.S. GRID 2 - MAP SIZE 10512 - J = 10512 - GO TO 800 - ELSE IF (KPDS(3).EQ.3) THEN -C ----- U.S. GRID 3 - MAP SIZE 65160 - J = 65160 - GO TO 800 - ELSE IF (KPDS(3).EQ.4) THEN -C ----- U.S. GRID 4 - MAP SIZE 259920 - J = 259920 - GO TO 800 - ELSE IF (KPDS(3).EQ.5) THEN -C ----- U.S. GRID 5 - MAP SIZE 3021 - J = 3021 - GO TO 800 - ELSE IF (KPDS(3).EQ.6) THEN -C ----- U.S. GRID 6 - MAP SIZE 2385 - J = 2385 - GO TO 800 - ELSE IF (KPDS(3).EQ.8) THEN -C ----- U.S. GRID 8 - MAP SIZE 5104 - J = 5104 - GO TO 800 - ELSE IF (KPDS(3).EQ.10) THEN -C ----- U.S. GRID 10 - MAP SIZE 25020 - J = 25020 - GO TO 800 - ELSE IF (KPDS(3).EQ.11) THEN -C ----- U.S. GRID 11 - MAP SIZE 223920 - J = 223920 - GO TO 800 - ELSE IF (KPDS(3).EQ.12) THEN -C ----- U.S. GRID 12 - MAP SIZE 99631 - J = 99631 - GO TO 800 - ELSE IF (KPDS(3).EQ.13) THEN -C ----- U.S. GRID 13 - MAP SIZE 36391 - J = 36391 - GO TO 800 - ELSE IF (KPDS(3).EQ.14) THEN -C ----- U.S. GRID 14 - MAP SIZE 153811 - J = 153811 - GO TO 800 - ELSE IF (KPDS(3).EQ.15) THEN -C ----- U.S. GRID 15 - MAP SIZE 74987 - J = 74987 - GO TO 800 - ELSE IF (KPDS(3).EQ.16) THEN -C ----- U.S. GRID 16 - MAP SIZE 214268 - J = 214268 - GO TO 800 - ELSE IF (KPDS(3).EQ.17) THEN -C ----- U.S. GRID 17 - MAP SIZE 387136 - J = 387136 - GO TO 800 - ELSE IF (KPDS(3).EQ.18) THEN -C ----- U.S. GRID 18 - MAP SIZE 281866 - J = 281866 - GO TO 800 - ELSE IF (KPDS(3).EQ.27.OR.KPDS(3).EQ.28) THEN -C ----- U.S. GRIDS 27, 28 - MAP SIZE 4225 - J = 4225 - GO TO 800 - ELSE IF (KPDS(3).EQ.29.OR.KPDS(3).EQ.30) THEN -C ----- U.S. GRIDS 29,30 - MAP SIZE 5365 - J = 5365 - GO TO 800 - ELSE IF (KPDS(3).EQ.33.OR.KPDS(3).EQ.34) THEN -C ----- U.S GRID 33, 34 - MAP SIZE 8326 - J = 8326 - GO TO 800 - ELSE IF (KPDS(3).GE.37.AND.KPDS(3).LE.44) THEN -C ----- U.S. GRID 37-44 - MAP SIZE 3447 - J = 3447 - GO TO 800 - ELSE IF (KPDS(3).EQ.45) THEN -C ----- U.S. GRID 45 - MAP SIZE 41760 - J = 41760 - GO TO 800 - ELSE IF (KPDS(3).EQ.53) THEN -C ----- U.S. GRID 53 - MAP SIZE 5967 - J = 5967 - GO TO 800 - ELSE IF (KPDS(3).EQ.55.OR.KPDS(3).EQ.56) THEN -C ----- U.S GRID 55, 56 - MAP SIZE 6177 - J = 6177 - GO TO 800 - ELSE IF (KPDS(3).GE.67.AND.KPDS(3).LE.71) THEN -C ----- U.S GRID 67-71 - MAP SIZE 13689 - J = 13689 - GO TO 800 - ELSE IF (KPDS(3).EQ.72) THEN -C ----- U.S GRID 72 - MAP SIZE 406 - J = 406 - GO TO 800 - ELSE IF (KPDS(3).EQ.73) THEN -C ----- U.S GRID 73 - MAP SIZE 13056 - J = 13056 - GO TO 800 - ELSE IF (KPDS(3).EQ.74) THEN -C ----- U.S GRID 74 - MAP SIZE 10800 - J = 10800 - GO TO 800 - ELSE IF (KPDS(3).GE.75.AND.KPDS(3).LE.77) THEN -C ----- U.S GRID 75-77 - MAP SIZE 12321 - J = 12321 - GO TO 800 - ELSE IF (KPDS(3).EQ.83) THEN -C ----- U.S GRID 83 - MAP SIZE 429786 - J = 429786 - GO TO 800 - ELSE IF (KPDS(3).EQ.85.OR.KPDS(3).EQ.86) THEN -C ----- U.S GRID 85,86 - MAP SIZE 32400 - J = 32400 - GO TO 800 - ELSE IF (KPDS(3).EQ.87) THEN -C ----- U.S GRID 87 - MAP SIZE 5022 - J = 5022 - GO TO 800 - ELSE IF (KPDS(3).EQ.88) THEN -C ----- U.S GRID 88 - MAP SIZE 317840 - J = 317840 - GO TO 800 - ELSE IF (KPDS(3).EQ.90) THEN -C ----- U.S GRID 90 - MAP SIZE 11807617 - J = 11807617 - GO TO 800 - ELSE IF (KPDS(3).EQ.91) THEN -C ----- U.S GRID 91 - MAP SIZE 1822145 - J = 1822145 - GO TO 800 - ELSE IF (KPDS(3).EQ.92) THEN -C ----- U.S GRID 92 - MAP SIZE 7283073 - J = 7283073 - GO TO 800 - ELSE IF (KPDS(3).EQ.93) THEN -C ----- U.S GRID 93 - MAP SIZE 111723 - J = 111723 - GO TO 800 - ELSE IF (KPDS(3).EQ.94) THEN -C ----- U.S GRID 94 - MAP SIZE 371875 - J = 371875 - GO TO 800 - ELSE IF (KPDS(3).EQ.95) THEN -C ----- U.S GRID 95 - MAP SIZE 130325 - J = 130325 - GO TO 800 - ELSE IF (KPDS(3).EQ.96) THEN -C ----- U.S GRID 96 - MAP SIZE 209253 - J = 209253 - GO TO 800 - ELSE IF (KPDS(3).EQ.97) THEN -C ----- U.S GRID 97 - MAP SIZE 1508100 - J = 1508100 - GO TO 800 - ELSE IF (KPDS(3).EQ.98) THEN -C ----- U.S GRID 98 - MAP SIZE 18048 - J = 18048 - GO TO 800 - ELSE IF (KPDS(3).EQ.99) THEN -C ----- U.S GRID 99 - MAP SIZE 779385 - J = 779385 - GO TO 800 - END IF - ELSE IF (KPDS(3).GE.100.AND.KPDS(3).LT.200) THEN - IF (KPDS(3).EQ.100) THEN -C ----- U.S. GRID 100 - MAP SIZE 6889 - J = 6889 - GO TO 800 - ELSE IF (KPDS(3).EQ.101) THEN -C ----- U.S. GRID 101 - MAP SIZE 10283 - J = 10283 - GO TO 800 - ELSE IF (KPDS(3).EQ.103) THEN -C ----- U.S. GRID 103 - MAP SIZE 3640 - J = 3640 - GO TO 800 - ELSE IF (KPDS(3).EQ.104) THEN -C ----- U.S. GRID 104 - MAP SIZE 16170 - J = 16170 - GO TO 800 - ELSE IF (KPDS(3).EQ.105) THEN -C ----- U.S. GRID 105 - MAP SIZE 6889 - J = 6889 - GO TO 800 - ELSE IF (KPDS(3).EQ.106) THEN -C ----- U.S. GRID 106 - MAP SIZE 19305 - J = 19305 - GO TO 800 - ELSE IF (KPDS(3).EQ.107) THEN -C ----- U.S. GRID 107 - MAP SIZE 11040 - J = 11040 - GO TO 800 - ELSE IF (KPDS(3).EQ.110) THEN -C ----- U.S. GRID 110 - MAP SIZE 103936 - J = 103936 - GO TO 800 - ELSE IF (KPDS(3).EQ.120) THEN -C ----- U.S. GRID 120 - MAP SIZE 2020800 - J = 2020800 - GO TO 800 - ELSE IF (KPDS(3).EQ.122) THEN -C ----- U.S. GRID 122 - MAP SIZE 162750 - J = 162750 - GO TO 800 - ELSE IF (KPDS(3).EQ.123) THEN -C ----- U.S. GRID 123 - MAP SIZE 100800 - J = 100800 - GO TO 800 - ELSE IF (KPDS(3).EQ.124) THEN -C ----- U.S. GRID 124 - MAP SIZE 75360 - J = 75360 - GO TO 800 - ELSE IF (KPDS(3).EQ.125) THEN -C ----- U.S. GRID 125 - MAP SIZE 102000 - J = 102000 - GO TO 800 - ELSE IF (KPDS(3).EQ.126) THEN -C ----- U.S. GRID 126 - MAP SIZE 72960 - J = 72960 - GO TO 800 - ELSE IF (KPDS(3).EQ.127) THEN -C ----- U.S. GRID 127 - MAP SIZE 294912 - J = 294912 - GO TO 800 - ELSE IF (KPDS(3).EQ.128) THEN -C ----- U.S. GRID 128 - MAP SIZE 663552 - J = 663552 - GO TO 800 - ELSE IF (KPDS(3).EQ.129) THEN -C ----- U.S. GRID 129 - MAP SIZE 1548800 - J = 1548800 - GO TO 800 - ELSE IF (KPDS(3).EQ.130) THEN -C ----- U.S. GRID 130 - MAP SIZE 151987 - J = 151987 - GO TO 800 - ELSE IF (KPDS(3).EQ.132) THEN -C ----- U.S. GRID 132 - MAP SIZE 385441 - J = 385441 - GO TO 800 - ELSE IF (KPDS(3).EQ.138) THEN -C ----- U.S. GRID 138 - MAP SIZE 134784 - J = 134784 - GO TO 800 - ELSE IF (KPDS(3).EQ.139) THEN -C ----- U.S. GRID 139 - MAP SIZE 4160 - J = 4160 - GO TO 800 - ELSE IF (KPDS(3).EQ.140) THEN -C ----- U.S. GRID 140 - MAP SIZE 32437 - J = 32437 - GO TO 800 -C - ELSE IF (KPDS(3).EQ.145) THEN -C ----- U.S. GRID 145 - MAP SIZE 24505 - J = 24505 - GO TO 800 - ELSE IF (KPDS(3).EQ.146) THEN -C ----- U.S. GRID 146 - MAP SIZE 23572 - J = 23572 - GO TO 800 - ELSE IF (KPDS(3).EQ.147) THEN -C ----- U.S. GRID 147 - MAP SIZE 69412 - J = 69412 - GO TO 800 - ELSE IF (KPDS(3).EQ.148) THEN -C ----- U.S. GRID 148 - MAP SIZE 117130 - J = 117130 - GO TO 800 - ELSE IF (KPDS(3).EQ.150) THEN -C ----- U.S. GRID 150 - MAP SIZE 806010 - J = 806010 - GO TO 800 - ELSE IF (KPDS(3).EQ.151) THEN -C ----- U.S. GRID 151 - MAP SIZE 205062 - J = 205062 - GO TO 800 - ELSE IF (KPDS(3).EQ.160) THEN -C ----- U.S. GRID 160 - MAP SIZE 28080 - J = 28080 - GO TO 800 - ELSE IF (KPDS(3).EQ.161) THEN -C ----- U.S. GRID 161 - MAP SIZE 13974 - J = 13974 - GO TO 800 - ELSE IF (KPDS(3).EQ.163) THEN -C ----- U.S. GRID 163 - MAP SIZE 727776 - J = 727776 - GO TO 800 - ELSE IF (KPDS(3).EQ.170) THEN -C ----- U.S. GRID 170 - MAP SIZE 131072 - J = 131072 - GO TO 800 - ELSE IF (KPDS(3).EQ.171) THEN -C ----- U.S. GRID 171 - MAP SIZE 716100 - J = 716100 - GO TO 800 - ELSE IF (KPDS(3).EQ.172) THEN -C ----- U.S. GRID 172 - MAP SIZE 489900 - J = 489900 - GO TO 800 - ELSE IF (KPDS(3).EQ.173) THEN -C ----- U.S. GRID 173 - MAP SIZE 9331200 - J = 9331200 - GO TO 800 - ELSE IF (KPDS(3).EQ.174) THEN -C ----- U.S. GRID 174 - MAP SIZE 4147200 - J = 4147200 - GO TO 800 - ELSE IF (KPDS(3).EQ.175) THEN -C ----- U.S. GRID 175 - MAP SIZE 185704 - J = 185704 - GO TO 800 - ELSE IF (KPDS(3).EQ.176) THEN -C ----- U.S. GRID 176 - MAP SIZE 76845 - J = 76845 - GO TO 800 - ELSE IF (KPDS(3).EQ.179) THEN -C ----- U.S. GRID 179 - MAP SIZE 977132 - J = 977132 - GO TO 800 - ELSE IF (KPDS(3).EQ.180) THEN -C ----- U.S. GRID 180 - MAP SIZE 267168 - J = 267168 - GO TO 800 - ELSE IF (KPDS(3).EQ.181) THEN -C ----- U.S. GRID 181 - MAP SIZE 102860 - J = 102860 - GO TO 800 - ELSE IF (KPDS(3).EQ.182) THEN -C ----- U.S. GRID 182 - MAP SIZE 64218 - J = 64218 - GO TO 800 - ELSE IF (KPDS(3).EQ.183) THEN -C ----- U.S. GRID 183 - MAP SIZE 180144 - J = 180144 - GO TO 800 - ELSE IF (KPDS(3).EQ.184) THEN -C ----- U.S. GRID 184 - MAP SIZE 2953665 - J = 2953665 - GO TO 800 - ELSE IF (KPDS(3).EQ.187) THEN -C ----- U.S. GRID 187 - MAP SIZE 3425565 - J = 3425565 - GO TO 800 - ELSE IF (KPDS(3).EQ.188) THEN -C ----- U.S. GRID 188 - MAP SIZE 563655 - J = 563655 - GO TO 800 - ELSE IF (KPDS(3).EQ.189) THEN -C ----- U.S. GRID 189 - MAP SIZE 560025 - J = 560025 - GO TO 800 - ELSE IF (KPDS(3).EQ.190) THEN -C ----- U.S GRID 190 - MAP SIZE 796590 - J = 796590 - GO TO 800 - ELSE IF (KPDS(3).EQ.192) THEN -C ----- U.S GRID 192 - MAP SIZE 91719 - J = 91719 - GO TO 800 - ELSE IF (KPDS(3).EQ.193) THEN -C ----- U.S GRID 193 - MAP SIZE 1038240 - J = 1038240 - GO TO 800 - ELSE IF (KPDS(3).EQ.194) THEN -C ----- U.S GRID 194 - MAP SIZE 168640 - J = 168640 - GO TO 800 - ELSE IF (KPDS(3).EQ.195) THEN -C ----- U.S. GRID 195 - MAP SIZE 22833 - J = 22833 - GO TO 800 - ELSE IF (KPDS(3).EQ.196) THEN -C ----- U.S. GRID 196 - MAP SIZE 72225 - J = 72225 - GO TO 800 - ELSE IF (KPDS(3).EQ.197) THEN -C ----- U.S. GRID 197 - MAP SIZE 739297 - J = 739297 - GO TO 800 - ELSE IF (KPDS(3).EQ.198) THEN -C ----- U.S. GRID 198 - MAP SIZE 456225 - J = 456225 - GO TO 800 - ELSE IF (KPDS(3).EQ.199) THEN -C ----- U.S. GRID 199 - MAP SIZE 37249 - J = 37249 - GO TO 800 - ELSE IF (IAND(KPDS(4),128).EQ.128) THEN -C ----- U.S. NON-STANDARD GRID - GO TO 895 - END IF - ELSE IF (KPDS(3).GE.200) THEN - IF (KPDS(3).EQ.200) THEN - J = 10152 - GO TO 800 - ELSE IF (KPDS(3).EQ.201) THEN - J = 4225 - GO TO 800 - ELSE IF (KPDS(3).EQ.202) THEN - J = 2795 - GO TO 800 - ELSE IF (KPDS(3).EQ.203.OR.KPDS(3).EQ.205) THEN - J = 1755 - GO TO 800 - ELSE IF (KPDS(3).EQ.204) THEN - J = 6324 - GO TO 800 - ELSE IF (KPDS(3).EQ.206) THEN - J = 2091 - GO TO 800 - ELSE IF (KPDS(3).EQ.207) THEN - J = 1715 - GO TO 800 - ELSE IF (KPDS(3).EQ.208) THEN - J = 783 - GO TO 800 - ELSE IF (KPDS(3).EQ.209) THEN - J = 61325 - GO TO 800 - ELSE IF (KPDS(3).EQ.210) THEN - J = 625 - GO TO 800 - ELSE IF (KPDS(3).EQ.211) THEN - J = 6045 - GO TO 800 - ELSE IF (KPDS(3).EQ.212) THEN - J = 23865 - GO TO 800 - ELSE IF (KPDS(3).EQ.213) THEN - J = 10965 - GO TO 800 - ELSE IF (KPDS(3).EQ.214) THEN - J = 6693 - GO TO 800 - ELSE IF (KPDS(3).EQ.215) THEN - J = 94833 - GO TO 800 - ELSE IF (KPDS(3).EQ.216) THEN - J = 14873 - GO TO 800 - ELSE IF (KPDS(3).EQ.217) THEN - J = 59001 - GO TO 800 - ELSE IF (KPDS(3).EQ.218) THEN - J = 262792 - GO TO 800 - ELSE IF (KPDS(3).EQ.219) THEN - J = 179025 - GO TO 800 - ELSE IF (KPDS(3).EQ.220) THEN - J = 122475 - GO TO 800 - ELSE IF (KPDS(3).EQ.221) THEN - J = 96673 - GO TO 800 - ELSE IF (KPDS(3).EQ.222) THEN - J = 15456 - GO TO 800 - ELSE IF (KPDS(3).EQ.223) THEN - J = 16641 - GO TO 800 - ELSE IF (KPDS(3).EQ.224) THEN - J = 4225 - GO TO 800 - ELSE IF (KPDS(3).EQ.225) THEN - J = 24975 - GO TO 800 - ELSE IF (KPDS(3).EQ.226) THEN - J = 381029 - GO TO 800 - ELSE IF (KPDS(3).EQ.227) THEN - J = 1509825 - GO TO 800 - ELSE IF (KPDS(3).EQ.228) THEN - J = 10512 - GO TO 800 - ELSE IF (KPDS(3).EQ.229) THEN - J = 65160 - GO TO 800 - ELSE IF (KPDS(3).EQ.230) THEN - J = 259920 - GO TO 800 - ELSE IF (KPDS(3).EQ.231) THEN - J = 130320 - GO TO 800 - ELSE IF (KPDS(3).EQ.232) THEN - J = 32760 - GO TO 800 - ELSE IF (KPDS(3).EQ.233) THEN - J = 45216 - GO TO 800 - ELSE IF (KPDS(3).EQ.234) THEN - J = 16093 - GO TO 800 - ELSE IF (KPDS(3).EQ.235) THEN - J = 259200 - GO TO 800 - ELSE IF (KPDS(3).EQ.236) THEN - J = 17063 - GO TO 800 - ELSE IF (KPDS(3).EQ.237) THEN - J = 2538 - GO TO 800 - ELSE IF (KPDS(3).EQ.238) THEN - J = 55825 - GO TO 800 - ELSE IF (KPDS(3).EQ.239) THEN - J = 19065 - GO TO 800 - ELSE IF (KPDS(3).EQ.240) THEN - J = 987601 - GO TO 800 - ELSE IF (KPDS(3).EQ.241) THEN - J = 244305 - GO TO 800 - ELSE IF (KPDS(3).EQ.242) THEN - J = 235025 - GO TO 800 - ELSE IF (KPDS(3).EQ.243) THEN - J = 12726 - GO TO 800 - ELSE IF (KPDS(3).EQ.244) THEN - J = 55825 - GO TO 800 - ELSE IF (KPDS(3).EQ.245) THEN - J = 124992 - GO TO 800 - ELSE IF (KPDS(3).EQ.246) THEN - J = 123172 - GO TO 800 - ELSE IF (KPDS(3).EQ.247) THEN - J = 124992 - GO TO 800 - ELSE IF (KPDS(3).EQ.248) THEN - J = 13635 - GO TO 800 - ELSE IF (KPDS(3).EQ.249) THEN - J = 125881 - GO TO 800 - ELSE IF (KPDS(3).EQ.250) THEN - J = 13635 - GO TO 800 - ELSE IF (KPDS(3).EQ.251) THEN - J = 69720 - GO TO 800 - ELSE IF (KPDS(3).EQ.252) THEN - J = 67725 - GO TO 800 - ELSE IF (KPDS(3).EQ.253) THEN - J = 83552 - GO TO 800 - ELSE IF (KPDS(3).EQ.254) THEN - J = 110700 - GO TO 800 - ELSE IF (IAND(KPDS(4),128).EQ.128) THEN - GO TO 895 - END IF - KRET = 5 - RETURN - END IF - END IF -C ------------------------------------------------------- -C CHECK JAPAN METEOROLOGICAL AGENCY SET -C ------------------------------------------------------- - IF (KPDS(1).EQ.34) THEN - IF (IAND(KPDS(4),128).EQ.128) THEN -C PRINT *,'JMA MAP IS NOT PREDEFINED, THE GDS WILL' -C PRINT *,'BE USED TO UNPACK THE DATA, MAP = ',KPDS(3) - GO TO 900 - END IF - END IF -C ------------------------------------------------------- -C CHECK CANADIAN SET -C ------------------------------------------------------- - IF (KPDS(1).EQ.54) THEN - IF (IAND(KPDS(4),128).EQ.128) THEN -C PRINT *,'CANADIAN MAP IS NOT PREDEFINED, THE GDS WILL' -C PRINT *,'BE USED TO UNPACK THE DATA, MAP = ',KPDS(3) - GO TO 900 - END IF - END IF -C ------------------------------------------------------- -C CHECK FNOC SET -C ------------------------------------------------------- - IF (KPDS(1).EQ.58) THEN - IF (KPDS(3).EQ.220.OR.KPDS(3).EQ.221) THEN -C FNOC GRID 220, 221 - MAPSIZE 3969 (63 * 63) - J = 3969 - KPTR(10) = J - DO I = 1, J - KBMS(I) = .TRUE. - END DO - RETURN - END IF - IF (KPDS(3).EQ.223) THEN -C FNOC GRID 223 - MAPSIZE 10512 (73 * 144) - J = 10512 - KPTR(10) = J - DO I = 1, J - KBMS(I) = .TRUE. - END DO - RETURN - END IF - IF (IAND(KPDS(4),128).EQ.128) THEN -C PRINT *,'FNOC MAP IS NOT PREDEFINED, THE GDS WILL' -C PRINT *,'BE USED TO UNPACK THE DATA, MAP = ',KPDS(3) - GO TO 900 - END IF - END IF -C ------------------------------------------------------- -C CHECK UKMET SET -C ------------------------------------------------------- - IF (KPDS(1).EQ.74) THEN - IF (IAND(KPDS(4),128).EQ.128) THEN - GO TO 820 - END IF - END IF -C ------------------------------------------------------- -C CHECK ECMWF SET -C ------------------------------------------------------- - IF (KPDS(1).EQ.98) THEN - IF (KPDS(3).GE.1.AND.KPDS(3).LE.12) THEN - IF (KPDS(3).GE.5.AND.KPDS(3).LE.8) THEN - J = 1073 - ELSE - J = 1369 - END IF - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 810 - KPTR(10) = J ! Reset For Modified J - DO 1000 I = 1, J - KBMS(I) = .TRUE. - 1000 CONTINUE - RETURN - ELSE IF (KPDS(3).GE.13.AND.KPDS(3).LE.16) THEN - J = 361 - KPTR(10) = J - CALL FI637(J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 810 - DO 1013 I = 1, J - KBMS(I) = .TRUE. - 1013 CONTINUE - RETURN - ELSE IF (IAND(KPDS(4),128).EQ.128) THEN - GO TO 810 - ELSE - KRET = 5 - RETURN - END IF - ELSE -C PRINT *,'CENTER ',KPDS(1),' IS NOT DEFINED' - IF (IAND(KPDS(4),128).EQ.128) THEN -C PRINT *,'GDS WILL BE USED TO UNPACK THE DATA', -C * ' MAP = ',KPDS(3) - GO TO 900 - ELSE - KRET = 10 - RETURN - END IF - END IF -C ======================================= -C - 800 CONTINUE - KPTR(10) = J - CALL FI637 (J,KPDS,KGDS,KRET) - IF(KRET.NE.0) GO TO 801 - DO 2201 I = 1, J - KBMS(I) = .TRUE. - 2201 CONTINUE - RETURN - 801 CONTINUE -C -C ----- THE MAP HAS A GDS, BYTE 7 OF THE (PDS) THE GRID IDENTIFICATION -C ----- IS NOT 255, THE SIZE OF THE GRID IS NOT THE SAME AS THE -C ----- PREDEFINED SIZES OF THE U.S. GRIDS, OR KNOWN GRIDS OF THE -C ----- OF THE OTHER CENTERS. THE GRID CAN BE UNKNOWN, OR FROM AN -C ----- UNKNOWN CENTER, WE WILL USE THE INFORMATION IN THE GDS TO MAKE -C ----- A BIT MAP. -C - 810 CONTINUE -C PRINT *,'ECMWF PREDEFINED MAP SIZE DOES NOT MATCH, I WILL USE' - GO TO 895 -C - 820 CONTINUE -C PRINT *,'U.K. MET PREDEFINED MAP SIZE DOES NOT MATCH, I WILL USE' - GO TO 895 -C - 890 CONTINUE -C PRINT *,'PREDEFINED MAP SIZE DOES NOT MATCH, I WILL USE' - 895 CONTINUE -C PRINT *,'THE GDS TO UNPACK THE DATA, MAP TYPE = ',KPDS(3) -C - 900 CONTINUE - J = KGDS(2) * KGDS(3) -C AFOS AFOS AFOS SPECIAL CASE -C INVOLVES NEXT SINGLE STATEMENT ONLY - IF (KPDS(3).EQ.211) KRET = 0 - KPTR(10) = J - DO 2203 I = 1, J - KBMS(I) = .TRUE. - 2203 CONTINUE -C PRINT *,'EXIT FI634' - RETURN - END -C----------------------------------------------------------------------- - SUBROUTINE FI634X(NPTS,NSKP,MSGA,KBMS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI634X EXTRACT BIT MAP -C PRGMMR: IREDELL ORG: W/NP23 DATE: 91-09-19 -C -C ABSTRACT: EXTRACT THE PACKED BITMAP INTO A LOGICAL ARRAY. -C -C PROGRAM HISTORY LOG: -C 97-09-19 IREDELL VECTORIZED BITMAP DECODER -C -C USAGE: CALL FI634X(NPTS,NSKP,MSGA,KBMS) -C INPUT ARGUMENT LIST: -C NPTS - INTEGER NUMBER OF POINTS IN THE BITMAP FIELD -C NSKP - INTEGER NUMBER OF BITS TO SKIP IN GRIB MESSAGE -C MSGA - CHARACTER*1 GRIB MESSAGE -C -C OUTPUT ARGUMENT LIST: -C KBMS - LOGICAL*1 BITMAP -C -C REMARKS: -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: CRAY -C -C$$$ - CHARACTER*1 MSGA(*) - LOGICAL*1 KBMS(NPTS) - INTEGER ICHK(NPTS) -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - CALL GBYTESC(MSGA,ICHK,NSKP,1,0,NPTS) - KBMS=ICHK.NE.0 -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - END - SUBROUTINE FI635(MSGA,KPTR,KPDS,KGDS,KBMS,DATA,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI635 EXTRACT GRIB DATA ELEMENTS FROM BDS -C PRGMMR: BILL CAVANAUGH ORG: W/NMC42 DATE: 91-09-13 -C -C ABSTRACT: EXTRACT GRIB DATA FROM BINARY DATA SECTION AND PLACE -C INTO OUTPUT ARRAY IN PROPER POSITION. -C -C PROGRAM HISTORY LOG: -C 91-09-13 CAVANAUGH -C 94-04-01 CAVANAUGH MODIFIED CODE TO INCLUDE DECIMAL SCALING WHEN -C CALCULATING THE VALUE OF DATA POINTS SPECIFIED -C AS BEING EQUAL TO THE REFERENCE VALUE -C 94-11-10 FARLEY INCREASED MXSIZE FROM 72960 TO 260000 -C FOR .5 DEGREE SST ANALYSIS FIELDS -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-08-31 IREDELL ELIMINATED NEED FOR MXSIZE -C -C USAGE: CALL FI635(MSGA,KPTR,KPDS,KGDS,KBMS,DATA,KRET) -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C (1) - TOTAL LENGTH OF GRIB MESSAGE -C (2) - LENGTH OF INDICATOR (SECTION 0) -C (3) - LENGTH OF PDS (SECTION 1) -C (4) - LENGTH OF GDS (SECTION 2) -C (5) - LENGTH OF BMS (SECTION 3) -C (6) - LENGTH OF BDS (SECTION 4) -C (7) - VALUE OF CURRENT BYTE -C (8) - BIT POINTER -C (9) - GRIB START BIT NR -C (10) - GRIB/GRID ELEMENT COUNT -C (11) - NR UNUSED BITS AT END OF SECTION 3 -C (12) - BIT MAP FLAG -C (13) - NR UNUSED BITS AT END OF SECTION 2 -C (14) - BDS FLAGS -C (15) - NR UNUSED BITS AT END OF SECTION 4 -C (16) - RESERVED -C (17) - RESERVED -C (18) - RESERVED -C (19) - BINARY SCALE FACTOR -C (20) - NUM BITS USED TO PACK EACH DATUM -C KPDS - ARRAY CONTAINING PDS ELEMENTS. -C SEE INITIAL ROUTINE -C KBMS - BITMAP DESCRIBING LOCATION OF OUTPUT ELEMENTS. -C -C OUTPUT ARGUMENT LIST: -C KBDS - INFORMATION EXTRACTED FROM BINARY DATA SECTION -C KBDS(1) - N1 -C KBDS(2) - N2 -C KBDS(3) - P1 -C KBDS(4) - P2 -C KBDS(5) - BIT POINTER TO 2ND ORDER WIDTHS -C KBDS(6) - " " " " " BIT MAPS -C KBDS(7) - " " " FIRST ORDER VALUES -C KBDS(8) - " " " SECOND ORDER VALUES -C KBDS(9) - " " START OF BDS -C KBDS(10) - " " MAIN BIT MAP -C KBDS(11) - BINARY SCALING -C KBDS(12) - DECIMAL SCALING -C KBDS(13) - BIT WIDTH OF FIRST ORDER VALUES -C KBDS(14) - BIT MAP FLAG -C 0 = NO SECOND ORDER BIT MAP -C 1 = SECOND ORDER BIT MAP PRESENT -C KBDS(15) - SECOND ORDER BIT WIDTH -C KBDS(16) - CONSTANT / DIFFERENT WIDTHS -C 0 = CONSTANT WIDTHS -C 1 = DIFFERENT WIDTHS -C KBDS(17) - SINGLE DATUM / MATRIX -C 0 = SINGLE DATUM AT EACH GRID POINT -C 1 = MATRIX OF VALUES AT EACH GRID POINT -C (18-20)- UNUSED -C -C DATA - REAL*4 ARRAY OF GRIDDED ELEMENTS IN GRIB MESSAGE. -C KPTR - ARRAY CONTAINING STORAGE FOR FOLLOWING PARAMETERS -C SEE INPUT LIST -C KRET - ERROR RETURN -C -C REMARKS: -C ERROR RETURN -C 3 = UNPACKED FIELD IS LARGER THAN 65160 -C 6 = DOES NOT MATCH NR OF ENTRIES FOR THIS GRIB/GRID -C 7 = NUMBER OF BITS IN FILL TOO LARGE -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS9000 -C -C$$$ -C - CHARACTER*1 MSGA(*) -C - LOGICAL*1 KBMS(*) -C - INTEGER KPDS(*) - INTEGER KGDS(*) - INTEGER KBDS(20) - INTEGER KPTR(*) - INTEGER NRBITS - INTEGER,ALLOCATABLE:: KSAVE(:) - INTEGER KSCALE -C - REAL DATA(*) - REAL REFNCE - REAL SCALE - REAL REALKK -C -C -C CHANGED HEX VALUES TO DECIMAL TO MAKE CODE MORE PORTABLE -C -C ************************************************************* -C PRINT *,'ENTER FI635' -C SET UP BIT POINTER - KPTR(8) = KPTR(9) + (KPTR(2)*8) + (KPTR(3)*8) + (KPTR(4)*8) - * + (KPTR(5)*8) + 24 -C ------------- EXTRACT FLAGS -C BYTE 4 - CALL GBYTEC(MSGA,KPTR(14),KPTR(8),4) - KPTR(8) = KPTR(8) + 4 -C --------- NR OF UNUSED BITS IN SECTION 4 - CALL GBYTEC(MSGA,KPTR(15),KPTR(8),4) - KPTR(8) = KPTR(8) + 4 - KEND = KPTR(9) + (KPTR(2)*8) + (KPTR(3)*8) + (KPTR(4)*8) - * + (KPTR(5)*8) + KPTR(6) * 8 - KPTR(15) -C ------------- GET SCALE FACTOR -C BYTES 5,6 -C CHECK SIGN - CALL GBYTEC (MSGA,KSIGN,KPTR(8),1) - KPTR(8) = KPTR(8) + 1 -C GET ABSOLUTE SCALE VALUE - CALL GBYTEC (MSGA,KSCALE,KPTR(8),15) - KPTR(8) = KPTR(8) + 15 - IF (KSIGN.GT.0) THEN - KSCALE = - KSCALE - END IF - SCALE = 2.0**KSCALE - KPTR(19)=KSCALE -C ------------ GET REFERENCE VALUE -C BYTES 7,10 -C CALL GBYTE (MSGA,KREF,KPTR(8),32) - call gbytec(MSGA,JSGN,KPTR(8),1) - call gbytec(MSGA,JEXP,KPTR(8)+1,7) - call gbytec(MSGA,IFR,KPTR(8)+8,24) - KPTR(8) = KPTR(8) + 32 -C -C THE NEXT CODE WILL CONVERT THE IBM370 FLOATING POINT -C TO THE FLOATING POINT USED ON YOUR COMPUTER. -C -C -C PRINT *,109,JSGN,JEXP,IFR -C 109 FORMAT (' JSGN,JEXP,IFR = ',3(1X,Z8)) - IF (IFR.EQ.0) THEN - REFNCE = 0.0 - ELSE IF (JEXP.EQ.0.AND.IFR.EQ.0) THEN - REFNCE = 0.0 - ELSE - REFNCE = FLOAT(IFR) * 16.0 ** (JEXP - 64 - 6) - IF (JSGN.NE.0) REFNCE = - REFNCE - END IF -C PRINT *,'SCALE ',SCALE,' REF VAL ',REFNCE -C ------------- NUMBER OF BITS SPECIFIED FOR EACH ENTRY -C BYTE 11 - CALL GBYTEC (MSGA,KBITS,KPTR(8),8) - KPTR(8) = KPTR(8) + 8 - KBDS(4) = KBITS -C KBDS(13) = KBITS - KPTR(20) = KBITS - IBYT12 = KPTR(8) -C ------------------ IF THERE ARE NO EXTENDED FLAGS PRESENT -C THIS IS WHERE DATA BEGINS AND AND THE PROCESSING -C INCLUDED IN THE FOLLOWING IF...END IF -C WILL BE SKIPPED -C PRINT *,'BASIC FLAGS =',KPTR(14) ,IAND(KPTR(14),1) - IF (IAND(KPTR(14),1).EQ.0) THEN -C PRINT *,'NO EXTENDED FLAGS' - ELSE -C BYTES 12,13 - CALL GBYTEC (MSGA,KOCTET,KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C --------------------------- EXTENDED FLAGS -C BYTE 14 - CALL GBYTEC (MSGA,KXFLAG,KPTR(8),8) -C PRINT *,'HAVE EXTENDED FLAGS',KXFLAG - KPTR(8) = KPTR(8) + 8 - IF (IAND(KXFLAG,16).EQ.0) THEN -C SECOND ORDER VALUES CONSTANT WIDTHS - KBDS(16) = 0 - ELSE -C SECOND ORDER VALUES DIFFERENT WIDTHS - KBDS(16) = 1 - END IF - IF (IAND (KXFLAG,32).EQ.0) THEN -C NO SECONDARY BIT MAP - KBDS(14) = 0 - ELSE -C HAVE SECONDARY BIT MAP - KBDS(14) = 1 - END IF - IF (IAND (KXFLAG,64).EQ.0) THEN -C SINGLE DATUM AT GRID POINT - KBDS(17) = 0 - ELSE -C MATRIX OF VALUES AT GRID POINT - KBDS(17) = 1 - END IF -C ---------------------- NR - FIRST DIMENSION (ROWS) OF EACH MATRIX -C BYTES 15,16 - CALL GBYTEC (MSGA,NR,KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ---------------------- NC - SECOND DIMENSION (COLS) OF EACH MATRIX -C BYTES 17,18 - CALL GBYTEC (MSGA,NC,KPTR(8),16) - KPTR(8) = KPTR(8) + 16 -C ---------------------- NRV - FIRST DIM COORD VALS -C BYTE 19 - CALL GBYTEC (MSGA,NRV,KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ---------------------- NC1 - NR COEFF'S OR VALUES -C BYTE 20 - CALL GBYTEC (MSGA,NC1,KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ---------------------- NCV - SECOND DIM COORD OR VALUE -C BYTE 21 - CALL GBYTEC (MSGA,NCV,KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ---------------------- NC2 - NR COEFF'S OR VALS -C BYTE 22 - CALL GBYTEC (MSGA,NC2,KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ---------------------- KPHYS1 - FIRST DIM PHYSICAL SIGNIF -C BYTE 23 - CALL GBYTEC (MSGA,KPHYS1,KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C ---------------------- KPHYS2 - SECOND DIM PHYSICAL SIGNIF -C BYTE 24 - CALL GBYTEC (MSGA,KPHYS2,KPTR(8),8) - KPTR(8) = KPTR(8) + 8 -C BYTES 25-N - END IF - IF (KBITS.EQ.0) THEN -C HAVE NO BDS ENTRIES, ALL ENTRIES = REFNCE - SCAL10 = 10.0 ** KPDS(22) - SCAL10 = 1.0 / SCAL10 - REFN10 = REFNCE * SCAL10 - KENTRY = KPTR(10) - DO 210 I = 1, KENTRY - DATA(I) = 0.0 - IF (KBMS(I)) THEN - DATA(I) = REFN10 - END IF - 210 CONTINUE - GO TO 900 - END IF -C PRINT *,'KEND ',KEND,' KPTR(8) ',KPTR(8),'KBITS ',KBITS - KNR = (KEND - KPTR(8)) / KBITS -C PRINT *,'NUMBER OF ENTRIES IN DATA ARRAY',KNR -C -------------------- -C CYCLE THRU BDS UNTIL HAVE USED ALL (SPECIFIED NUMBER) -C ENTRIES. -C ------------- UNUSED BITS IN DATA AREA -C NUMBER OF BYTES IN DATA AREA - NRBYTE = KPTR(6) - 11 -C ------------- TOTAL NR OF USABLE BITS - NRBITS = NRBYTE * 8 - KPTR(15) -C ------------- TOTAL NR OF ENTRIES - KENTRY = NRBITS / KBITS -C ALLOCATE KSAVE - ALLOCATE(KSAVE(KENTRY)) -C -C IF (IAND(KPTR(14),2).EQ.0) THEN -C PRINT *,'SOURCE VALUES IN FLOATING POINT' -C ELSE -C PRINT *,'SOURCE VALUES IN INTEGER' -C END IF -C - IF (IAND(KPTR(14),8).EQ.0) THEN -C PRINT *,'PROCESSING GRID POINT DATA' - IF (IAND(KPTR(14),4).EQ.0) THEN -C PRINT *,' WITH SIMPLE PACKING' - IF (IAND(KPTR(14),1).EQ.0) THEN -C PRINT *,' WITH NO ADDITIONAL FLAGS' - GO TO 4000 - ELSE IF (IAND(KPTR(14),1).NE.0) THEN -C PRINT *,' WITH ADDITIONAL FLAGS',KXFLAG - IF (KBDS(17).EQ.0) THEN -C PRINT *,' SINGLE DATUM EACH GRID PT' - IF (KBDS(14).EQ.0) THEN -C PRINT *,' NO SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - ELSE IF (KBDS(14).NE.0) THEN -C PRINT *,' SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - END IF - ELSE IF (KBDS(17).NE.0) THEN -C PRINT *,' MATRIX OF VALS EACH PT' - IF (KBDS(14).EQ.0) THEN -C PRINT *,' NO SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - ELSE IF (KBDS(14).NE.0) THEN -C PRINT *,' SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - END IF - END IF - END IF - ELSE IF (IAND(KPTR(14),4).NE.0) THEN -C PRINT *,' WITH COMPLEX/SECOND ORDER PACKING' - IF (IAND(KPTR(14),1).EQ.0) THEN -C PRINT *,' WITH NO ADDITIONAL FLAGS' - ELSE IF (IAND(KPTR(14),1).NE.0) THEN -C PRINT *,' WITH ADDITIONAL FLAGS' - IF (KBDS(17).EQ.0) THEN -C PRINT *,' SINGLE DATUM AT EACH PT' - IF (KBDS(14).EQ.0) THEN -C PRINT *,' NO SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF -C ROW BY ROW - COL BY COL - CALL FI636 (DATA,MSGA,KBMS, - * REFNCE,KPTR,KPDS,KGDS) - GO TO 900 - ELSE IF (KBDS(14).NE.0) THEN -C PRINT *,' SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - CALL FI636 (DATA,MSGA,KBMS, - * REFNCE,KPTR,KPDS,KGDS) - GO TO 900 - END IF - ELSE IF (KBDS(17).NE.0) THEN -C PRINT *,' MATRIX OF VALS EACH PT' - IF (KBDS(14).EQ.0) THEN -C PRINT *,' NO SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - ELSE IF (KBDS(14).NE.0) THEN -C PRINT *,' SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - END IF - END IF - END IF - END IF - ELSE IF (IAND(KPTR(14),8).NE.0) THEN -C PRINT *,'PROCESSING SPHERICAL HARMONIC COEFFICIENTS' - IF (IAND(KPTR(14),4).EQ.0) THEN -C PRINT *,' WITH SIMPLE PACKING' - IF (IAND(KPTR(14),1).EQ.0) THEN -C PRINT *,' WITH NO ADDITIONAL FLAGS' - GO TO 5000 - ELSE IF (IAND(KPTR(14),1).NE.0) THEN -C PRINT *,' WITH ADDITIONAL FLAGS' - IF (KBDS(17).EQ.0) THEN -C PRINT *,' SINGLE DATUM EACH GRID PT' - IF (KBDS(14).EQ.0) THEN -C PRINT *,' NO SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - ELSE IF (KBDS(14).NE.0) THEN -C PRINT *,' SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - END IF - ELSE IF (KBDS(17).NE.0) THEN -C PRINT *,' MATRIX OF VALS EACH PT' - IF (KBDS(14).EQ.0) THEN -C PRINT *,' NO SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - ELSE IF (KBDS(14).NE.0) THEN -C PRINT *,' SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - END IF - END IF - END IF - ELSE IF (IAND(KPTR(14),4).NE.0) THEN -C COMPLEX/SECOND ORDER PACKING -C PRINT *,' WITH COMPLEX/SECOND ORDER PACKING' - IF (IAND(KPTR(14),1).EQ.0) THEN -C PRINT *,' WITH NO ADDITIONAL FLAGS' - ELSE IF (IAND(KPTR(14),1).NE.0) THEN -C PRINT *,' WITH ADDITIONAL FLAGS' - IF (KBDS(17).EQ.0) THEN -C PRINT *,' SINGLE DATUM EACH GRID PT' - IF (KBDS(14).EQ.0) THEN -C PRINT *,' NO SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - ELSE IF (KBDS(14).NE.0) THEN -C PRINT *,' SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - END IF - ELSE IF (KBDS(17).NE.0) THEN -C PRINT *,' MATRIX OF VALS EACH PT' - IF (KBDS(14).EQ.0) THEN -C PRINT *,' NO SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - ELSE IF (KBDS(14).NE.0) THEN -C PRINT *,' SEC BIT MAP' - IF (KBDS(16).EQ.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES CONSTANT WIDTH' - ELSE IF (KBDS(16).NE.0) THEN -C PRINT *,' SECOND ORDER', -C * ' VALUES DIFFERENT WIDTHS' - END IF - END IF - END IF - END IF - END IF - END IF - IF(ALLOCATED(KSAVE)) DEALLOCATE(KSAVE) -C PRINT *,' NOT PROCESSED - NOT PROCESSED - NOT PROCESSED' - KRET = 11 - RETURN - 4000 CONTINUE -C **************************************************************** -C -C GRID POINT DATA, SIMPLE PACKING, FLOATING POINT, NO ADDN'L FLAGS -C - SCAL10 = 10.0 ** KPDS(22) - SCAL10 = 1.0 / SCAL10 - IF (KPDS(3).EQ.23.OR.KPDS(3).EQ.24.OR.KPDS(3).EQ.26. - * OR.KPDS(3).EQ.63.OR.KPDS(3).EQ.64) THEN - IF (KPDS(3).EQ.26) THEN - KADD = 72 - ELSE IF (KPDS(3).EQ.63.OR.KPDS(3).EQ.64) THEN - KADD = 91 - ELSE - KADD = 37 - END IF - CALL GBYTESC (MSGA,KSAVE,KPTR(8),KBITS,0,KNR) - KPTR(8) = KPTR(8) + KBITS * KNR - II = 1 - KENTRY = KPTR(10) - DO 4001 I = 1, KENTRY - IF (KBMS(I)) THEN - DATA(I) = (REFNCE+FLOAT(KSAVE(II))*SCALE)*SCAL10 - II = II + 1 - ELSE - DATA(I) = 0.0 - END IF - 4001 CONTINUE - DO 4002 I = 2, KADD - DATA(I) = DATA(1) - 4002 CONTINUE - ELSE IF (KPDS(3).EQ.21.OR.KPDS(3).EQ.22.OR.KPDS(3).EQ.25. - * OR.KPDS(3).EQ.61.OR.KPDS(3).EQ.62) THEN - CALL GBYTESC (MSGA,KSAVE,KPTR(8),KBITS,0,KNR) - II = 1 - KENTRY = KPTR(10) - DO 4011 I = 1, KENTRY - IF (KBMS(I)) THEN - DATA(I) = (REFNCE + FLOAT(KSAVE(II)) * SCALE) * SCAL10 - II = II + 1 - ELSE - DATA(I) = 0.0 - END IF - 4011 CONTINUE - IF (KPDS(3).EQ.25) THEN - KADD = 71 - ELSE IF (KPDS(3).EQ.61.OR.KPDS(3).EQ.62) THEN - KADD = 90 - ELSE - KADD = 36 - END IF - LASTP = KENTRY - KADD - DO 4012 I = LASTP+1, KENTRY - DATA(I) = DATA(LASTP) - 4012 CONTINUE - ELSE - CALL GBYTESC (MSGA,KSAVE,KPTR(8),KBITS,0,KNR) - II = 1 - KENTRY = KPTR(10) - DO 500 I = 1, KENTRY - IF (KBMS(I)) THEN - DATA(I) = (REFNCE + FLOAT(KSAVE(II)) * SCALE) * SCAL10 - II = II + 1 - ELSE - DATA(I) = 0.0 - END IF - 500 CONTINUE - END IF - GO TO 900 -C ------------- PROCESS SPHERICAL HARMONIC COEFFICIENTS, -C SIMPLE PACKING, FLOATING POINT, NO ADDN'L FLAGS - 5000 CONTINUE -C PRINT *,'CHECK POINT SPECTRAL COEFF' - KPTR(8) = IBYT12 -C CALL GBYTE (MSGA,KKK,KPTR(8),32) - call gbytec(MSGA,JSGN,KPTR(8),1) - call gbytec(MSGA,JEXP,KPTR(8)+1,7) - call gbytec(MSGA,IFR,KPTR(8)+8,24) - KPTR(8) = KPTR(8) + 32 -C -C THE NEXT CODE WILL CONVERT THE IBM370 FOATING POINT -C TO THE FLOATING POINT USED ON YOUR MACHINE. -C - IF (IFR.EQ.0) THEN - REALKK = 0.0 - ELSE IF (JEXP.EQ.0.AND.IFR.EQ.0) THEN - REALKK = 0.0 - ELSE - REALKK = FLOAT(IFR) * 16.0 ** (JEXP - 64 - 6) - IF (JSGN.NE.0) REALKK = -REALKK - END IF - DATA(1) = REALKK - CALL GBYTESC (MSGA,KSAVE,KPTR(8),KBITS,0,KNR) -C -------------- - DO 6000 I = 1, KENTRY - DATA(I+1) = REFNCE + FLOAT(KSAVE(I)) * SCALE - 6000 CONTINUE - 900 CONTINUE - IF(ALLOCATED(KSAVE)) DEALLOCATE(KSAVE) -C PRINT *,'EXIT FI635' - RETURN - END - SUBROUTINE FI636 (DATA,MSGA,KBMS,REFNCE,KPTR,KPDS,KGDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI636 PROCESS SECOND ORDER PACKING -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 92-09-22 -C -C ABSTRACT: PROCESS SECOND ORDER PACKING FROM THE BINARY DATA SECTION -C (BDS) FOR SINGLE DATA ITEMS GRID POINT DATA -C -C PROGRAM HISTORY LOG: -C 93-06-08 CAVANAUGH -C 93-12-15 CAVANAUGH MODIFIED SECOND ORDER POINTERS TO FIRST ORDER -C VALUES AND SECOND ORDER VALUES CORRECTLY. -C 95-04-26 R.E.JONES FI636 CORECTION FOR 2ND ORDER COMPLEX -C UNPACKING. -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL FI636 (DATA,MSGA,KBMS,REFNCE,KPTR,KPDS,KGDS) -C INPUT ARGUMENT LIST: -C -C MSGA - ARRAY CONTAINING GRIB MESSAGE -C REFNCE - REFERENCE VALUE -C KPTR - WORK ARRAY -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C DATA - LOCATION OF OUTPUT ARRAY -C WORKING ARRAY -C KBDS(1) - N1 -C KBDS(2) - N2 -C KBDS(3) - P1 -C KBDS(4) - P2 -C KBDS(5) - BIT POINTER TO 2ND ORDER WIDTHS -C KBDS(6) - " " " " " BIT MAPS -C KBDS(7) - " " " FIRST ORDER VALUES -C KBDS(8) - " " " SECOND ORDER VALUES -C KBDS(9) - " " START OF BDS -C KBDS(10) - " " MAIN BIT MAP -C KBDS(11) - BINARY SCALING -C KBDS(12) - DECIMAL SCALING -C KBDS(13) - BIT WIDTH OF FIRST ORDER VALUES -C KBDS(14) - BIT MAP FLAG -C 0 = NO SECOND ORDER BIT MAP -C 1 = SECOND ORDER BIT MAP PRESENT -C KBDS(15) - SECOND ORDER BIT WIDTH -C KBDS(16) - CONSTANT / DIFFERENT WIDTHS -C 0 = CONSTANT WIDTHS -C 1 = DIFFERENT WIDTHS -C KBDS(17) - SINGLE DATUM / MATRIX -C 0 = SINGLE DATUM AT EACH GRID POINT -C 1 = MATRIX OF VALUES AT EACH GRID POINT -C (18-20)- UNUSED -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS, CRAY -C -C$$$ - REAL DATA(*) - REAL REFN - REAL REFNCE -C - INTEGER KBDS(20) - INTEGER KPTR(*) - character(len=1) BMAP2(1000000) - INTEGER I,IBDS - INTEGER KBIT,IFOVAL,ISOVAL - INTEGER KPDS(*),KGDS(*) -C - LOGICAL*1 KBMS(*) -C - CHARACTER*1 MSGA(*) -C -C ******************* SETUP ****************************** -C PRINT *,'ENTER FI636' -C START OF BMS (BIT POINTER) - DO I = 1,20 - KBDS(I) = 0 - END DO -C BYTE START OF BDS - IBDS = KPTR(2) + KPTR(3) + KPTR(4) + KPTR(5) -C PRINT *,'KPTR(2-5) ',KPTR(2),KPTR(3),KPTR(4),KPTR(5) -C BIT START OF BDS - JPTR = IBDS * 8 -C PRINT *,'JPTR ',JPTR - KBDS(9) = JPTR -C PRINT *,'START OF BDS ',KBDS(9) -C BINARY SCALE VALUE BDS BYTES 5-6 - CALL GBYTEC (MSGA,ISIGN,JPTR+32,1) - CALL GBYTEC (MSGA,KBDS(11),JPTR+33,15) - IF (ISIGN.GT.0) THEN - KBDS(11) = - KBDS(11) - END IF -C PRINT *,'BINARY SCALE VALUE =',KBDS(11) -C EXTRACT REFERENCE VALUE -C CALL GBYTEC(MSGA,JREF,JPTR+48,32) - call gbytec(MSGA,JSGN,KPTR(8),1) - call gbytec(MSGA,JEXP,KPTR(8)+1,7) - call gbytec(MSGA,IFR,KPTR(8)+8,24) - IF (IFR.EQ.0) THEN - REFNCE = 0.0 - ELSE IF (JEXP.EQ.0.AND.IFR.EQ.0) THEN - REFNCE = 0.0 - ELSE - REFNCE = FLOAT(IFR) * 16.0 ** (JEXP - 64 - 6) - IF (JSGN.NE.0) REFNCE = - REFNCE - END IF -C PRINT *,'DECODED REFERENCE VALUE =',REFN,REFNCE -C F O BIT WIDTH - CALL GBYTEC(MSGA,KBDS(13),JPTR+80,8) - JPTR = JPTR + 88 -C AT START OF BDS BYTE 12 -C EXTRACT N1 - CALL GBYTEC (MSGA,KBDS(1),JPTR,16) -C PRINT *,'N1 = ',KBDS(1) - JPTR = JPTR + 16 -C EXTENDED FLAGS - CALL GBYTEC (MSGA,KFLAG,JPTR,8) -C ISOLATE BIT MAP FLAG - IF (IAND(KFLAG,32).NE.0) THEN - KBDS(14) = 1 - ELSE - KBDS(14) = 0 - END IF - IF (IAND(KFLAG,16).NE.0) THEN - KBDS(16) = 1 - ELSE - KBDS(16) = 0 - END IF - IF (IAND(KFLAG,64).NE.0) THEN - KBDS(17) = 1 - ELSE - KBDS(17) = 0 - END IF - JPTR = JPTR + 8 -C EXTRACT N2 - CALL GBYTEC (MSGA,KBDS(2),JPTR,16) -C PRINT *,'N2 = ',KBDS(2) - JPTR = JPTR + 16 -C EXTRACT P1 - CALL GBYTEC (MSGA,KBDS(3),JPTR,16) -C PRINT *,'P1 = ',KBDS(3) - JPTR = JPTR + 16 -C EXTRACT P2 - CALL GBYTEC (MSGA,KBDS(4),JPTR,16) -C PRINT *,'P2 = ',KBDS(4) - JPTR = JPTR + 16 -C SKIP RESERVED BYTE - JPTR = JPTR + 8 -C START OF SECOND ORDER BIT WIDTHS - KBDS(5) = JPTR -C COMPUTE START OF SECONDARY BIT MAP - IF (KBDS(14).NE.0) THEN -C FOR INCLUDED SECONDARY BIT MAP - JPTR = JPTR + (KBDS(3) * 8) - KBDS(6) = JPTR - ELSE -C FOR CONSTRUCTED SECONDARY BIT MAP - KBDS(6) = 0 - END IF -C CREATE POINTER TO START OF FIRST ORDER VALUES - KBDS(7) = KBDS(9) + KBDS(1) * 8 - 8 -C PRINT *,'BIT POINTER TO START OF FOVALS',KBDS(7) -C CREATE POINTER TO START OF SECOND ORDER VALUES - KBDS(8) = KBDS(9) + KBDS(2) * 8 - 8 -C PRINT *,'BIT POINTER TO START OF SOVALS',KBDS(8) -C PRINT *,'KBDS( 1) - N1 ',KBDS( 1) -C PRINT *,'KBDS( 2) - N2 ',KBDS( 2) -C PRINT *,'KBDS( 3) - P1 ',KBDS( 3) -C PRINT *,'KBDS( 4) - P2 ',KBDS( 4) -C PRINT *,'KBDS( 5) - BIT PTR - 2ND ORDER WIDTHS ',KBDS( 5) -C PRINT *,'KBDS( 6) - " " " " BIT MAPS ',KBDS( 6) -C PRINT *,'KBDS( 7) - " " F O VALS ',KBDS( 7) -C PRINT *,'KBDS( 8) - " " S O VALS ',KBDS( 8) -C PRINT *,'KBDS( 9) - " " START OF BDS ',KBDS( 9) -C PRINT *,'KBDS(10) - " " MAIN BIT MAP ',KBDS(10) -C PRINT *,'KBDS(11) - BINARY SCALING ',KBDS(11) -C PRINT *,'KPDS(22) - DECIMAL SCALING ',KPDS(22) -C PRINT *,'KBDS(13) - FO BIT WIDTH ',KBDS(13) -C PRINT *,'KBDS(14) - 2ND ORDER BIT MAP FLAG ',KBDS(14) -C PRINT *,'KBDS(15) - 2ND ORDER BIT WIDTH ',KBDS(15) -C PRINT *,'KBDS(16) - CONSTANT/DIFFERENT WIDTHS ',KBDS(16) -C PRINT *,'KBDS(17) - SINGLE DATUM/MATRIX ',KBDS(17) -C PRINT *,'REFNCE VAL ',REFNCE -C ************************* PROCESS DATA ********************** - IJ = 0 -C ======================================================== - IF (KBDS(14).EQ.0) THEN -C NO BIT MAP, MUST CONSTRUCT ONE - IF (KGDS(2).EQ.65535) THEN - IF (KGDS(20).EQ.255) THEN -C PRINT *,'CANNOT BE USED HERE' - ELSE -C POINT TO PL - LP = KPTR(9) + KPTR(2)*8 + KPTR(3)*8 + KGDS(20)*8 - 8 -C PRINT *,'LP = ',LP - JT = 0 - DO 2000 JZ = 1, KGDS(3) -C GET NUMBER IN CURRENT ROW - CALL GBYTEC (MSGA,NUMBER,LP,16) -C INCREMENT TO NEXT ROW NUMBER - LP = LP + 16 -C PRINT *,'NUMBER IN ROW',JZ,' = ',NUMBER - DO 1500 JQ = 1, NUMBER - IF (JQ.EQ.1) THEN - CALL SBYTEC (BMAP2,1,JT,1) - ELSE - CALL SBYTEC (BMAP2,0,JT,1) - END IF - JT = JT + 1 - 1500 CONTINUE - 2000 CONTINUE - END IF - ELSE - IF (IAND(KGDS(11),32).EQ.0) THEN -C ROW BY ROW -C PRINT *,' ROW BY ROW' - KOUT = KGDS(3) - KIN = KGDS(2) - ELSE -C COL BY COL -C PRINT *,' COL BY COL' - KIN = KGDS(3) - KOUT = KGDS(2) - END IF -C PRINT *,'KIN=',KIN,' KOUT= ',KOUT - DO 200 I = 1, KOUT - DO 150 J = 1, KIN - IF (J.EQ.1) THEN - CALL SBYTEC (BMAP2,1,IJ,1) - ELSE - CALL SBYTEC (BMAP2,0,IJ,1) - END IF - IJ = IJ + 1 - 150 CONTINUE - 200 CONTINUE - END IF - END IF -C ======================================================== -C PRINT 99,(BMAP2(J),J=1,110) -C99 FORMAT ( 10(1X,Z8.8)) -C CALL BINARY (BMAP2,2) -C FOR EACH GRID POINT ENTRY -C - SCALE2 = 2.0**KBDS(11) - SCAL10 = 10.0**KPDS(22) -C PRINT *,'SCALE VALUES - ',SCALE2,SCAL10 - DO 1000 I = 1, KPTR(10) -C GET NEXT MASTER BIT MAP BIT POSITION -C IF NEXT MASTER BIT MAP BIT POSITION IS 'ON' (1) - IF (KBMS(I)) THEN -C WRITE(6,900)I,KBMS(I) -C 900 FORMAT (1X,I4,3X,14HMAIN BIT IS ON,3X,L4) - IF (KBDS(14).NE.0) THEN - CALL GBYTEC (MSGA,KBIT,KBDS(6),1) - ELSE - CALL GBYTEC (BMAP2,KBIT,KBDS(6),1) - END IF -C PRINT *,'KBDS(6) =',KBDS(6),' KBIT =',KBIT - KBDS(6) = KBDS(6) + 1 - IF (KBIT.NE.0) THEN -C PRINT *,' SOB ON' -C GET NEXT FIRST ORDER PACKED VALUE - CALL GBYTEC (MSGA,IFOVAL,KBDS(7),KBDS(13)) - KBDS(7) = KBDS(7) + KBDS(13) -C PRINT *,'FOVAL =',IFOVAL -C GET SECOND ORDER BIT WIDTH - CALL GBYTEC (MSGA,KBDS(15),KBDS(5),8) - KBDS(5) = KBDS(5) + 8 -C PRINT *,KBDS(7)-KBDS(13),' FOVAL =',IFOVAL,' KBDS(5)=', -C * ,KBDS(5), 'ISOWID =',KBDS(15) - ELSE -C PRINT *,' SOB NOT ON' - END IF - ISOVAL = 0 - IF (KBDS(15).EQ.0) THEN -C IF SECOND ORDER BIT WIDTH = 0 -C THEN SECOND ORDER VALUE IS 0 -C SO CALCULATE DATA VALUE FOR THIS POINT -C DATA(I) = (REFNCE + (FLOAT(IFOVAL) * SCALE2)) / SCAL10 - ELSE - CALL GBYTEC (MSGA,ISOVAL,KBDS(8),KBDS(15)) - KBDS(8) = KBDS(8) + KBDS(15) - END IF - DATA(I) = (REFNCE + (FLOAT(IFOVAL + ISOVAL) * - * SCALE2)) / SCAL10 -C PRINT *,I,DATA(I),REFNCE,IFOVAL,ISOVAL,SCALE2,SCAL10 - ELSE -C WRITE(6,901) I,KBMS(I) -C 901 FORMAT (1X,I4,3X,15HMAIN BIT NOT ON,3X,L4) - DATA(I) = 0.0 - END IF -C PRINT *,I,DATA(I),IFOVAL,ISOVAL,KBDS(5),KBDS(15) - 1000 CONTINUE -C ************************************************************** -C PRINT *,'EXIT FI636' - RETURN - END - SUBROUTINE FI637(J,KPDS,KGDS,KRET) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI637 GRIB GRID/SIZE TEST -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 91-09-13 -C -C ABSTRACT: TO TEST WHEN GDS IS AVAILABLE TO SEE IF SIZE MISMATCH -C ON EXISTING GRIDS (BY CENTER) IS INDICATED -C -C PROGRAM HISTORY LOG: -C 91-09-13 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 97-02-12 W BOSTELMAN CORRECTS ECMWF US GRID 2 PROCESSING -C 98-06-17 IREDELL REMOVED ALTERNATE RETURN -C 99-01-20 BALDWIN MODIFY TO HANDLE GRID 237 -C 09-05-21 VUONG MODIFY TO HANDLE GRID 45 -C -C USAGE: CALL FI637(J,KPDS,KGDS,KRET) -C INPUT ARGUMENT LIST: -C J - SIZE FOR INDICATED GRID -C KPDS - -C KGDS - -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C J - SIZE FOR INDICATED GRID MODIFIED FOR ECMWF-US 2 -C KRET - ERROR RETURN -C (A MISMATCH WAS DETECTED IF KRET IS NOT ZERO) -C -C REMARKS: -C KRET - -C = 9 - GDS INDICATES SIZE MISMATCH WITH STD GRID -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS -C -C$$$ - INTEGER KPDS(*) - INTEGER KGDS(*) - INTEGER J - INTEGER I -C --------------------------------------- -C --------------------------------------- -C IF GDS NOT INDICATED, RETURN -C ---------------------------------------- - KRET=0 - IF (IAND(KPDS(4),128).EQ.0) RETURN -C --------------------------------------- -C GDS IS INDICATED, PROCEED WITH TESTING -C --------------------------------------- - IF (KGDS(2).EQ.65535) THEN - RETURN - END IF - KRET=1 - I = KGDS(2) * KGDS(3) -C --------------------------------------- -C INTERNATIONAL SET -C --------------------------------------- - IF (KPDS(3).GE.21.AND.KPDS(3).LE.26) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.37.AND.KPDS(3).LE.44) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.50) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.61.AND.KPDS(3).LE.64) THEN - IF (I.NE.J) THEN - RETURN - END IF -C --------------------------------------- -C TEST ECMWF CONTENT -C --------------------------------------- - ELSE IF (KPDS(1).EQ.98) THEN - KRET = 9 - IF (KPDS(3).GE.1.AND.KPDS(3).LE.16) THEN - IF (I.NE.J) THEN - IF (KPDS(3) .NE. 2) THEN - RETURN - ELSEIF (I .NE. 10512) THEN ! Test for US Grid 2 - RETURN - END IF - J = I ! Set to US Grid 2, 2.5 Global - END IF - ELSE - KRET = 5 - RETURN - END IF -C --------------------------------------- -C U.K. MET OFFICE, BRACKNELL -C --------------------------------------- - ELSE IF (KPDS(1).EQ.74) THEN - KRET = 9 - IF (KPDS(3).GE.25.AND.KPDS(3).LE.26) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE - KRET = 5 - RETURN - END IF -C --------------------------------------- -C CANADA -C --------------------------------------- - ELSE IF (KPDS(1).EQ.54) THEN -C PRINT *,' NO CURRENT LISTING OF CANADIAN GRIDS' - RETURN -C --------------------------------------- -C JAPAN METEOROLOGICAL AGENCY -C --------------------------------------- - ELSE IF (KPDS(1).EQ.34) THEN -C PRINT *,' NO CURRENT LISTING OF JMA GRIDS' - RETURN -C --------------------------------------- -C NAVY - FNOC -C --------------------------------------- - ELSE IF (KPDS(1).EQ.58) THEN - IF (KPDS(3).GE.37.AND.KPDS(3).LE.44) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.220.AND.KPDS(3).LE.221) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.223) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE - KRET = 5 - RETURN - END IF -C --------------------------------------- -C U.S. GRIDS -C --------------------------------------- - ELSE IF (KPDS(1).EQ.7) THEN - KRET = 9 - IF (KPDS(3).GE.1.AND.KPDS(3).LE.6) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.8) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.10) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.11.AND.KPDS(3).LE.18) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.27.AND.KPDS(3).LE.30) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.33.AND.KPDS(3).LE.34) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.37.AND.KPDS(3).LE.45) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.53) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.55.AND.KPDS(3).LE.56) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.67.AND.KPDS(3).LE.77) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.85.AND.KPDS(3).LE.88) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.90.AND.KPDS(3).LE.99) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.100.OR.KPDS(3).EQ.101) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.103.AND.KPDS(3).LE.107) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.110) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.120) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.122.AND.KPDS(3).LE.130) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.132) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.138) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.139) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.140) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.145.AND.KPDS(3).LE.148) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.150.OR.KPDS(3).EQ.151) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.160.OR.KPDS(3).EQ.161) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.163) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.170.AND.KPDS(3).LE.176) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.179.AND.KPDS(3).LE.184) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.187) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.188) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.189) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).EQ.190.OR.KPDS(3).EQ.192) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.193.AND.KPDS(3).LE.199) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE IF (KPDS(3).GE.200.AND.KPDS(3).LE.254) THEN - IF (I.NE.J) THEN - RETURN - END IF - ELSE - KRET = 5 - RETURN - END IF - ELSE - KRET = 10 - RETURN - END IF -C ------------------------------------ -C NORMAL EXIT -C ------------------------------------ - KRET = 0 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi64.f b/external/w3nco/v2.0.6/src/w3fi64.f deleted file mode 100644 index 2c7f1aca4..000000000 --- a/external/w3nco/v2.0.6/src/w3fi64.f +++ /dev/null @@ -1,760 +0,0 @@ - SUBROUTINE W3FI64(COCBUF,LOCRPT,NEXT) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI64 NMC OFFICE NOTE 29 REPORT UNPACKER -C PRGMMR: KEYSER ORG: NMC22 DATE:92-08-06 -C -C ABSTRACT: UNPACKS AN ARRAY OF UPPER-AIR REPORTS THAT ARE PACKED IN -C THE FORMAT DESCRIBED BY NMC OFFICE NOTE 29, OR UNPACKS AN ARRAY -C OF SURFACE REPORTS THAT ARE PACKED IN THE FORMAT DESCRIBED BY NMC -C OFFICE NOTE 124. INPUT CHARACTER DATA ARE CONVERTED TO INTEGER, -C REAL OR CHARACTER TYPE AS SPECIFIED IN THE CATEGORY TABLES BELOW. -C MISSING INTEGER DATA ARE REPLACED WITH 99999, MISSING REAL DATA -C ARE REPLACED WITH 99999.0 AND MISSING CHARACTER DATA ARE REPLACED -C WITH BLANKS. THIS LIBRARY IS SIMILAR TO W3AI02 EXCEPT W3AI02 -C WAS WRITTEN IN ASSEMBLER AND COULD NOT HANDLE INTERNAL READ ERRORS -C (PROGRAM CALLING W3AI02 WOULD FAIL IN THIS CASE W/O EXPLANATION). -C -C PROGRAM HISTORY LOG: -C 90-01-?? L. MARX, UNIV. OF MD -- CONVERTED CODE FROM ASSEMBLER -C TO VS FORTRAN; EXPANDED ERROR RETURN CODES IN 'NEXT' -C 91-07-22 D. A. KEYSER, NMC22 -- USE SAME ARGUMENTS AS W3AI02; -C STREAMLINED CODE; DOCBLOCKED AND COMMENTED; DIAG- -C NOSTIC PRINT FOR ERRORS; ATTEMPTS TO SKIP TO NEXT -C REPORT IN SAME RECORD RATHER THAN EXITING RECORD -C 91-08-12 D. A. KEYSER, NMC22 -- SLIGHT CHANGES TO MAKE SUB- -C PROGRAM MORE PORTABLE; TEST FOR ABSENCE OF END- -C OF-RECORD INDICATOR, WILL GRACEFULLY EXIT RECORD -C 92-06-29 D. A. KEYSER W/NMC22 -- CONVERT TO CRAY CFT77 FORTRAN -C 92-08-06 D. A. KEYSER, NMC22 -- CORRECTED ERROR WHICH COULD -C LEAD TO THE LENGTH FOR A CONCATENATION OPERATOR -C BEING LESS THAN 1 WHEN AN INPUT PARAMETER SPANS -C ACROSS TWO 10-CHARACTER WORDS -C -C USAGE: CALL W3FI64(COCBUF,LOCRPT,NEXT) -C INPUT ARGUMENT LIST: -C COCBUF - CHARACTER*10 ARRAY CONTAINING A BLOCK OF PACKED -C - REPORTS IN NMC OFFICE NOTE 29/124 FORMAT. -C NEXT - MARKER INDICATING RELATIVE LOCATION (IN BYTES) OF -C - END OF LAST REPORT IN COCBUF. EXCEPTION: NEXT MUST -C - BE SET TO ZERO PRIOR TO UNPACKING THE FIRST REPORT OF -C - A NEW BLOCK OF REPORTS. SUBSEQUENTLY, THE VALUE OF -C - NEXT RETURNED BY THE PREVIOUS CALL TO W3FI64 SHOULD -C - BE USED AS INPUT. (SEE OUTPUT ARGUMENT LIST BELOW.) -C - IF NEXT IS NEGATIVE, W3FI64 WILL RETURN IMMEDIATELY -C - WITHOUT ACTION. -C -C OUTPUT ARGUMENT LIST: -C LOCRPT - ARRAY CONTAINING ONE UNPACKED REPORT WITH POINTERS -C - AND COUNTERS TO DIRECT THE USER. LOCRPT MUST BEGIN -C - ON A FULLWORD BOUNDARY. FORMAT IS MIXED, USER MUST -C - EQUIVALENCE REAL AND CHARACTER ARRAYS TO THIS ARRAY -C - (SEE BELOW AND REMARKS FOR CONTENT). -C *************************************************************** -C WORD CONTENT UNIT FORMAT -C ---- ---------------------- ------------------- --------- -C 1 LATITUDE 0.01 DEGREES REAL -C 2 LONGITUDE 0.01 DEGREES WEST REAL -C 3 UNUSED -C 4 OBSERVATION TIME 0.01 HOURS (UTC) REAL -C 5 RESERVED (3RD BYTE IS 4-CHARACTERS CHAR*8 -C ON29 "25'TH CHAR.; 4TH LEFT-JUSTIFIED -C BYTE IS ON29 "26'TH -C CHAR." (SEE ON29) -C 6 RESERVED (3RD BYTE IS 3-CHARACTERS CHAR*8 -C ON29 "27'TH CHAR. (SEE LEFT-JUSTIFIED -C ON29) -C 7 STATION ELEVATION METERS REAL -C 8 INSTRUMENT TYPE ON29 TABLE R.2 INTEGER -C 9 REPORT TYPE ON29 TABLE R.1 OR INTEGER -C ON124 TABLE S.3 -C 10 UNUNSED -C 11 STN. ID. (FIRST 4 CHAR.) 4-CHARACTERS CHAR*8 -C LEFT-JUSTIFIED -C 12 STN. ID. (LAST 2 CHAR.) 2-CHARACTERS CHAR*8 -C LEFT-JUSTIFIED -C -C 13 CATEGORY 1, NO. LEVELS COUNT INTEGER -C 14 CATEGORY 1, DATA INDEX COUNT INTEGER -C 15 CATEGORY 2, NO. LEVELS COUNT INTEGER -C 16 CATEGORY 2, DATA INDEX COUNT INTEGER -C 17 CATEGORY 3, NO. LEVELS COUNT INTEGER -C 18 CATEGORY 3, DATA INDEX COUNT INTEGER -C 19 CATEGORY 4, NO. LEVELS COUNT INTEGER -C 20 CATEGORY 4, DATA INDEX COUNT INTEGER -C 21 CATEGORY 5, NO. LEVELS COUNT INTEGER -C 22 CATEGORY 5, DATA INDEX COUNT INTEGER -C 23 CATEGORY 6, NO. LEVELS COUNT INTEGER -C 24 CATEGORY 6, DATA INDEX COUNT INTEGER -C 25 CATEGORY 7, NO. LEVELS COUNT INTEGER -C 26 CATEGORY 7, DATA INDEX COUNT INTEGER -C 27 CATEGORY 8, NO. LEVELS COUNT INTEGER -C 28 CATEGORY 8, DATA INDEX COUNT INTEGER -C 29 CATEGORY 51, NO. LEVELS COUNT INTEGER -C 30 CATEGORY 51, DATA INDEX COUNT INTEGER -C 31 CATEGORY 52, NO. LEVELS COUNT INTEGER -C 32 CATEGORY 52, DATA INDEX COUNT INTEGER -C 33 CATEGORY 9, NO. LEVELS COUNT INTEGER -C 34 CATEGORY 9, DATA INDEX COUNT INTEGER -C 35-42 ZEROED OUT - NOT USED INTEGER -C -C 43-END UNPACKED DATA GROUPS (SEE REMARKS) MIXED -C *************************************************************** -C -C NEXT - MARKER INDICATING RELATIVE LOCATION (IN BYTES) -C - OF END OF CURRENT REPORT IN COCBUF. NEXT WILL BE -C - SET TO -1 IF W3FI64 ENCOUNTERS STRING 'END RECORD' -C - IN PLACE OF THE NEXT REPORT. THIS IS THE END OF THE -C - BLOCK. NO UNPACKING TAKES PLACE. NEXT IS SET TO-2 -C - WHEN INTERNAL (LOGIC) ERRORS HAVE BEEN DETECTED. -C - NEXT IS SET TO -3 WHEN DATA COUNT CHECK FAILS. IN -C - BOTH OF THE LATTER CASES SOME DATA (E.G., HEADER -C - INFORMATION) MAY BE UNPACKED INTO LOCRPT. -C -C OUTPUT FILES: -C FT06F001 - PRINTOUT -C -C REMARKS: AFTER FIRST READING AND PROCESSING THE OFFICE NOTE 85 -C (FIRST) DATE RECORD, THE USER'S FORTRAN PROGRAM BEGINS A READ -C LOOP AS FOLLOWS.. FOR EACH ITERATION A BLOCKED INPUT REPORT IS -C READ INTO ARRAY COCBUF. NOW TEST THE FIRST TEN CHARACTERS IN -C COCBUF FOR THE STRING 'ENDOF FILE' (SIC). THIS STRING SIGNALS -C THE END OF INPUT. OTHERWISE, SET THE MARKER 'NEXT' TO ZERO AND -C BEGIN THE UNPACKING LOOP. -C EACH ITERATION OF THE UNPACKING LOOP CONSISTS OF A CALL TO -C W3FI64 WITH THE CURRENT VALUE OF 'NEXT'. IF 'NEXT' IS -1 UPON -C RETURNING FROM W3FI64, IT HAS REACHED THE END OF THE INPUT -C RECORD, AND THE USER'S PROGRAM SHOULD READ THE NEXT RECORD AS -C ABOVE. IF 'NEXT' IS -2 OR -3 UPON RETURNING, THERE IS A GRIEVOUS -C ERROR IN THE CURRENT PACKED INPUT RECORD, AND THE USER'S PROGRAM -C SHOULD PRINT IT FOR EXAMINATION BY AUTOMATION DIVISION PERSONNEL. -C IF 'NEXT' IS POSITIVE, THE OUTPUT STRUCTURE LOCRPT CONTAINS -C AN UNPACKED REPORT, AND THE USER'S PROGRAM SHOULD PROCESS IT AT -C THIS POINT, SUBSEQUENTLY REPEATING THE UNPACKING LOOP. -C -C EXAMPLE: -C CHARACTER*10 COCBUF(644) -C CHARACTER*8 COCRPT(1608) -C CHARACTER*3 CQUMAN(20) -C INTEGER LOCRPT(1608) -C REAL ROCRPT(1608),GEOMAN(20),TMPMAN(20),DPDMAN(20), -C $ WDRMAN(20),WSPMAN(20) -C EQUIVALENCE (COCRPT,LOCRPT,ROCRPT) -C .......... -C C READ AND PROCESS THE OFFICE NOTE 85 DATE RECORD -C .......... -C C --- BEGIN READ LOOP -C 10 CONTINUE -C READ (UNIT=INP, IOSTAT=IOS, NUM=NBUF) COCBUF -C IF(IOS .LT. 0) GO TO (END OF INPUT) -C IF(IOS .GT. 0) GO TO (INPUT ERROR) -C IF(NBUF .GT. 6432) GO TO (BUFFER OVERFLOW) -C IF(COCBUF(1).EQ.'ENDOF FILE') GO TO (END OF INPUT) -C NEXT = 0 -C C ------ BEGIN UNPACKING LOOP -C 20 CONTINUE -C CALL W3FI64(COCBUF, LOCRPT, NEXT) -C IF(NEXT .EQ. -1) GO TO 10 -C IF(NEXT .LT. -1) GO TO (OFFICE NOTE 29/124 ERROR) -C RLAT = 0.01 * ROCRPT(1) (LATITUDE) -C ..... ETC ..... -C C --- BEGIN CATEGORY 1 FETCH -- MANDATORY LEVEL DATA -C IF(LOCRPT(13) .GT. 0) THEN -C NLVLS = MIN(20,LOCRPT(13)) -C INDX = LOCRPT(14) -C DO 66 I = 1,NLVLS -C GEOMAN(I) = ROCRPT(INDX) -C TMPMAN(I) = 0.1 * ROCRPT(INDX+1) -C DPDMAN(I) = 0.1 * ROCRPT(INDX+2) -C WDRMAN(I) = ROCRPT(INDX+3) -C WSPMAN(I) = ROCRPT(INDX+4) -C CQUMAN(I) = COCRPT(INDX+5) -C INDX = INDX + 6 -C 66 CONTINUE -C END IF -C ..... ETC ..... -C GO TO 20 -C ............... -C -C DATA FROM THE ON29/124 RECORD IS UNPACKED INTO FIXED LOCATIONS -C IN WORDS 1-12 AND INTO INDEXED LOCATIONS IN WORD 43 AND -C FOLLOWING. STUDY ON29 APPENDIX C/ON124 APPENDIX S.2 CAREFULLY. -C EACH CATEGORY (OR GROUP OF FIELDS) IN THE PACKED REPORT HAS A -C CORRESPONDING LAYOUT IN LOCATIONS IN ARRAY LOCRPT THAT MAY BE -C FOUND BY USING THE CORRESPONDING INDEX AMOUNT FROM WORDS 14, 16, -C ..., 34, IN ARRAY LOCRPT. FOR INSTANCE, IF A REPORT CONTAINS -C ONE OR MORE PACKED CATEGORY 3 DATA GROUPS (WIND DATA AT VARIABLE -C PRESSURE LEVELS) THAT DATA WILL BE UNPACKED INTO BINARY AND -C AND CHARACTER FIELDS IN ONE OR MORE UNPACKED CATEGORY 3 DATA -C GROUPS AS DESCRIBED BELOW. THE NUMBER OF LEVELS WILL BE STORED -C IN WORD 17 AND THE INDEX IN FULLWORDS OF THE FIRST LEVEL OF -C UNPACKED DATA IN THE OUTPUT ARRAY WILL BE STORED IN WORD 18. -C THE SECOND LEVEL, IF ANY, WILL BE STORED BEGINNING FOUR WORDS -C FURTHER ON, AND SO FORTH UNTIL THE COUNT IN WORD 17 IS -C EXHAUSTED. THE FIELD LAYOUT IN EACH CATEGORY IS GIVEN BELOW... -C -C CATEGORY 1 - MANDATORY LEVEL DATA -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 GEOPOTENTIAL METERS REAL -C 2 TEMPERATURE 0.1 DEGREES C REAL -C 3 DEWPOINT DEPRESSION 0.1 DEGREES C REAL -C 4 WIND DIRECTION DEGREES REAL -C 5 WIND SPEED KNOTS REAL -C 6 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C GEOPOTENTIAL ON29 TABLE Q.A -C TEMPERATURE ON29 TABLE Q.A -C DEWPOINT DEPR. ON29 TABLE Q.C -C WIND ON29 TABLE Q.A -C -C CATEGORY 2 - TEMPERATURE AT VARIABLE PRESSURE -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 PRESSURE 0.1 MILLIBARS REAL -C 2 TEMPERATURE 0.1 DEGREES C REAL -C 3 DEWPOINT DEPRESSION 0.1 DEGREES C REAL -C 4 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C PRESSURE ON29 TABLE Q.B -C TEMPERATURE ON29 TABLE Q.A -C DEWPOINT DEPR. ON29 TABLE Q.C -C NOT USED BLANK -C -C CATEGORY 3 - WINDS AT VARIABLE PRESSURE -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 PRESSURE 0.1 MILLIBARS REAL -C 2 WIND DIRECTION DEGREES REAL -C 3 WIND SPEED KNOTS REAL -C 4 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C PRESSURE ON29 TABLE Q.B -C WIND ON29 TABLE Q.A -C NOT USED BLANK -C NOT USED BLANK -C -C CATEGORY 4 - WINDS AT VARIABLE HEIGHTS -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 GEOPOTENTIAL METERS REAL -C 2 WIND DIRECTION DEGREES REAL -C 3 WIND SPEED KNOTS REAL -C 4 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C GEOPOTENTIAL ON29 TABLE Q.B -C WIND ON29 TABLE Q.A -C NOT USED BLANK -C NOT USED BLANK -C -C CATEGORY 5 - TROPOPAUSE DATA -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 GEOPOTENTIAL METERS REAL -C 2 TEMPERATURE 0.1 DEGREES C REAL -C 3 DEWPOINT DEPRESSION 0.1 DEGREES C REAL -C 4 WIND DIRECTION DEGREES REAL -C 5 WIND SPEED KNOTS REAL -C 6 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C PRESSURE ON29 TABLE Q.B -C TEMPERATURE ON29 TABLE Q.A -C DEWPOINT DEPR. ON29 TABLE Q.C -C WIND ON29 TABLE Q.A -C -C CATEGORY 6 - CONSTANT-LEVEL DATA (AIRCRAFT, SAT. CLOUD-DRIFT) -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 PRESSURE ALTITUDE METERS REAL -C 2 TEMPERATURE 0.1 DEGREES C REAL -C 3 DEWPOINT DEPRESSION 0.1 DEGREES C REAL -C 4 WIND DIRECTION DEGREES REAL -C 5 WIND SPEED KNOTS REAL -C 6 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C PRESSURE ON29 TABLE Q.6 -C TEMPERATURE ON29 TABLE Q.6 -C DEWPOINT DEPR. ON29 TABLE Q.6 -C WIND ON29 TABLE Q.6C -C -C CATEGORY 7 - CLOUD COVER -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 PRESSURE 0.1 MILLIBARS REAL -C 2 AMOUNT OF CLOUDS PER CENT REAL -C 3 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C PRESSURE ON29 TABLE Q.7 -C CLOUD AMOUNT ON29 TABLE Q.7 -C NOT USED BLANK -C NOT USED BLANK -C -C CATEGORY 8 - ADDITIONAL DATA -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 SPECIFIED IN ON29 VARIABLE REAL -C TABLE 101.1 OR -C ON124 TABLE SM.8A.1 -C 2 FORM OF ADD'L DATA CODE FIGURE FROM REAL -C ON29 TABLE 101 OR -C ON124 TABLE SM.8A -C 3 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C VALUE 1 ON29 TABLE Q.8 OR -C ON124 TABLE SM.8B -C VALUE 2 ON29 TABLE Q.8A OR -C ON124 TABLE SM.8C -C NOT USED BLANK -C NOT USED BLANK -C -C CATEGORY 51 - SURFACE DATA -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 SEA-LEVEL PRESSURE 0.1 MILLIBARS REAL -C 2 STATION PRESSURE 0.1 MILLIBARS REAL -C 3 WIND DIRECTION DEGREES REAL -C 4 WIND SPEED KNOTS REAL -C 5 AIR TEMPERATURE 0.1 DEGREES C REAL -C 6 DEWPOINT DEPRESSION 0.1 DEGREES C REAL -C 7 MAXIMUM TEMPERATURE 0.1 DEGREES C REAL -C 8 MINIMUM TEMPERATURE 0.1 DEGREES C REAL -C 9 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C S-LEVEL PRESS. ON124 TABLE SM.51 -C STATION PRESS. ON124 TABLE SM.51 -C WIND ON124 TABLE SM.51 -C AIR TEMPERATURE ON124 TABLE SM.51 -C 10 QUALITY MARKERS: EACH 1-CHARACTER CHAR*8 -C LEFT-JUSTIFIED -C DEWPOINT DEPR. ON124 TABLE SM.51 -C NOT USED BLANK -C NOT USED BLANK -C NOT USED BLANK -C 11 HORIZ. VISIBILITY WMO CODE TABLE 4300 INTEGER -C 12 PRESENT WEATHER WMO CODE TABLE 4677 INTEGER -C 13 PAST WEATHER WMO CODE TABLE 4561 INTEGER -C 14 TOTAL CLOUD COVER N WMO CODE TABLE 2700 INTEGER -C 15 CLOUD COVER OF C/LN WMO CODE TABLE 2700 INTEGER -C 16 CLOUD TYPE OF C/L WMO CODE TABLE 0513 INTEGER -C 17 CLOUD HEIGHT OF C/L WMO CODE TABLE 1600 INTEGER -C 18 CLOUD TYPE OF C/M WMO CODE TABLE 0515 INTEGER -C 19 CLOUD TYPE OF C/H WMO CODE TABLE 0509 INTEGER -C 20 CHARACTERISTIC OF WMO CODE TABLE 0200 INTEGER -C 3-HR PRESS TENDENCY -C 21 AMT. PRESS TENDENCY 0.1 MILLIBARS REAL -C (50.0 WILL BE ADDED TO INDICATE 24-HR TENDENCY) -C -C CATEGORY 52 - ADDITIONAL SURFACE DATA -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 6-HR PRECIPITATION 0.01 INCH INTEGER -C 2 SNOW DEPTH INCH INTEGER -C 3 24-HR PRECIPITATION 0.01 INCH INTEGER -C 4 DURATION OF PRECIP. NO. 6-HR PERIODS INTEGER -C 5 PERIOD OF WAVES SECONDS INTEGER -C 6 HEIGHT OF WAVES 0.5 METERS INTEGER -C 7 SWELL DIRECTION WMO CODE TABLE 0877 INTEGER -C 8 SWELL PERIOD SECONDS INTEGER -C 9 SWELL HEIGHT 0.5 METERS INTEGER -C 10 SEA SFC TEMPERATURE 0.1 DEGREES C INTEGER -C 11 SPECIAL PHEN, GEN'L INTEGER -C 12 SPECIAL PHEN, DET'L INTEGER -C 13 SHIP'S COURSE WMO CODE TABLE 0700 INTEGER -C 14 SHIP'S AVERAGE SPEED WMO CODE TABLE 4451 INTEGER -C 15 WATER EQUIVALENT OF 0.01 INCH INTEGER -C SNOW AND/OR ICE -C -C CATEGORY 9 - PLAIN LANGUAGE DATA (ALPHANUMERIC TEXT) -C WORD BYTES PARAMETER FORMAT -C ---- ----- --------------------------------------- -------- -C 1 1 INDICATOR OF CONTENT (ON124 TABLE SM.9) CHAR*8 -C (1 CHARACTER) -C 2-4 PLAIN LANGUAGE DATA, TEXT CHARACTERS 1-3 -C 4-8 NOT USED (BLANK) -C 2 1-4 PLAIN LANGUAGE DATA, TEXT CHARACTERS 4-7 CHAR*8 -C 4-8 NOT USED (BLANK) -C 3 1-4 PLAIN LANGUAGE DATA, TEXT CHARACTERS 8-11 CHAR*8 -C 4-8 NOT USED (BLANK) -C -C ONE REPORT MAY UNPACK INTO MORE THAN ONE CATEGORY HAVING -C MULTIPLE LEVELS. THE UNUSED PORTION OF LOCRPT IS NOT CLEARED. -C -C NOTE: ENTRY W3AI02 DUPLICATES PROCESSING IN W3FI64 SINCE NO -C ASSEMBLY LANGUAGE CODE IN CRAY W3LIB. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/864 -C -C$$$ -C - CHARACTER*12 HOLD - CHARACTER*10 COCBUF(*) - CHARACTER*7 CNINES - CHARACTER*4 COCRPT(10000),BLANK - CHARACTER*2 KAT(11) -C - INTEGER LOCRPT(*),KATGC(20,11),KATGL(20,11),KATL(11),KATO(11), - $ MOCRPT(5000) -C - REAL ROCRPT(5000) -C - EQUIVALENCE (ROCRPT,MOCRPT,COCRPT) -C - SAVE -C - DATA BLANK/' '/,CNINES/'9999999'/,IMSG/99999/,XMSG/99999./ - DATA KATL/6,4,4,4,6,6,3,3,1,20,15/,KATO/13,15,17,19,21,23,25,27, - $ 33,29,31/,IREC/2/ - DATA KAT/'01','02','03','04','05','06','07','08','09','51','52'/ - DATA KATGC/ 5*2,4,14*0, 3*2,4,16*0, 3*2,4,16*0, 3*2,4,16*0, - $ 5*2,4,14*0, 5*2,4,14*0, 2*2,4,17*0, 2*2,4,17*0, 4,19*0, - $ 8*2,4,10*1,2, 15*1,5*0/ - DATA KATGL/ 5,4,3*3,4,14*0, 5,4,2*3,16*0, 5,2*3,2,16*0, - $ 5,2*3,2,16*0, 5,4,3*3,4,14*0, 5,4,3*3,4,14*0, 5,3,2,17*0, - $ 5,3,2,17*0, 12,19*0, - $ 2*5,2*3,4,3,2*4,5,2*3,7*2,1,3, 4,3,4,1,5*2,4,2*2,1,2,7,5*0/ - DATA LWFLAG/0/ -C - ENTRY W3AI02(COCBUF,LOCRPT,NEXT) -C - IF (LWFLAG.EQ.0) THEN -C FIRST TIME CALLED, DETERMINE MACHINE WORD LG IN BYTES (=8 FOR CRAY) -C DEPENDING ON WORD SIZE LW2*I-LW1 INDEXES THRU COCRPT -C EITHER AS 1,2,3...I FOR LW = 4 OR -C AS 1,3,5..2*I-1 FOR LW = 8 <------ HERE -C NECESSITATED BY LEFT JUSTIFICATION OF EQUIVALENCE - CALL W3FI01(LW) - LW2 = LW/4 - LW1 = LW/8 - LWFLAG = 1 - END IF - 7000 CONTINUE - IF(NEXT.LT.0) RETURN - NEXTO = NEXT/10 - N = NEXT/10 + 1 -C - IF(COCBUF(N).EQ.'END RECORD'.OR.COCBUF(N).EQ.'XXXXXXXXXX') THEN -C HIT END-OF-RECORD; RETURN WITH NEXT = -1 - IF(COCBUF(N).EQ.'XXXXXXXXXX') PRINT 109, IREC - IREC = IREC + 1 - NEXT = -1 - RETURN - END IF -C INITIALIZE REPORT ID AS MISSING OR 0 FOR RESERVED WORDS - ROCRPT(1) = XMSG - ROCRPT(2) = XMSG - ROCRPT(3) = 0. - ROCRPT(4) = XMSG - COCRPT(LW2*5-LW1) = ' ' - COCRPT(LW2*6-LW1) = ' ' - ROCRPT(7) = XMSG - MOCRPT(8) = 99 - MOCRPT(9) = IMSG - MOCRPT(10) = 0. - COCRPT(LW2*11-LW1) = ' ' - COCRPT(LW2*12-LW1) = ' ' -C INITIALIZE CATEGORY WORD PAIRS AS ZEROES - DO 100 MB = 13,42 - MOCRPT(MB) = 0 - 100 CONTINUE -C WRITE OUT LATITUDE INTO WORD 1 (REAL) - M = 1 - IF(COCBUF(N)(1:5).NE.'99999') READ(COCBUF(N)(1:5),51) ROCRPT(M) -C WRITE OUT LONGITUDE INTO WORD 2 (REAL) - M = 2 - IF(COCBUF(N)(6:10).NE.'99999') READ(COCBUF(N)(6:10),51) ROCRPT(M) -C WORD 3 IS RESERVED (KEEP AS A REAL NUMBER OF 0.) -C WRITE OUT STATION ID TO WORDS 11 AND 12 (CHAR*8) -C (CHAR. 1-4 OF ID IN WORD 11, CHAR. 5-6 OF ID IN WORD 12, LEFT-JUSTIF.) - M = 11 - N = N + 1 - COCRPT(LW2*M-LW1) = COCBUF(N)(1:4) - M = 12 - COCRPT(LW2*M-LW1) = COCBUF(N)(5:6)//' ' -C WRITE OUT OBSERVATION TIME INTO WORD 4 (REAL) - M = 4 - IF(COCBUF(N)(7:10).NE.'9999') READ(COCBUF(N)(7:10),41) ROCRPT(M) -C WORD 5 IS RESERVED (CHAR*8) (4 CHARACTERS, LEFT-JUSTIF.) - M = 5 - N = N + 1 - COCRPT(LW2*M-LW1) = COCBUF(N)(3:6) -C WORD 6 IS RESERVED (CHAR*8) (3 CHARACTERS, LEFT-JUSTIF.) - M = 6 - COCRPT(LW2*M-LW1) = COCBUF(N)(1:2)//COCBUF(N)(7:7)//' ' -C WRITE OUT REPORT TYPE INTO WORD 9 (INTEGER) - M = 9 - READ(COCBUF(N)(8:10),30) MOCRPT(M) -C WRITE OUT STATION ELEVATION INTO WORD 7 (REAL) - N = N + 1 - M = 7 - IF(COCBUF(N)(1:5).NE.'99999') READ(COCBUF(N)(1:5),51) ROCRPT(M) -C WRITE OUT INSTRUMENT TYPE INTO WORD 8 (INTEGER) - M = 8 - IF(COCBUF(N)(6:7).NE.'99') READ(COCBUF(N)(6:7),20) MOCRPT(M) -C READ IN NWDS, THE TOTAL NO. OF 10-CHARACTER WORDS IN ENTIRE REPORT - READ(COCBUF(N)(8:10),30) NWDS -C 'MO' WILL BE STARTING LOCATION IN MOCRPT FOR THE DATA - MO = 43 - N = N + 1 - 700 CONTINUE - IF(COCBUF(N).EQ.'END REPORT') THEN -C----------------------------------------------------------------------- -C HAVE HIT THE END OF THE REPORT - IF(N-NEXTO.EQ.NWDS) THEN -C EVERYTHING LOOKS GOOD, RETURN WITH NEXT SET TO LAST BYTE IN REPORT - NEXT = N * 10 - ELSE -C PROBLEM, MAY EXIT WITH NEXT = -3 - NEXTX = -3 - PRINT 101, - & COCRPT(LW2*11-LW1),COCRPT(LW2*12-LW1)(1:2),N-NEXTO,NWDS - GO TO 99 - END IF - MWORDS = MO - 1 - DO 1001 I =1, MWORDS - LOCRPT(I) = MOCRPT(I) - 1001 CONTINUE - RETURN -C----------------------------------------------------------------------- - END IF -C READ IN NWDSC, THE RELATIVE POSITION IN RPT OF THE NEXT CATEGORY - READ(COCBUF(N)(3:5),30) NWDSC -C READ IN LVLS, THE NUMBER OF LEVELS IN THE CURRENT CATEGORY - READ(COCBUF(N)(6:7),20) LVLS -C DETERMINE THE CATEGORY NUMBER OF THE CURRENT CATEGORY - DO 800 NCAT = 1,11 - IF(COCBUF(N)(1:2).EQ.KAT(NCAT)) GO TO 1000 - 800 CONTINUE -C----------------------------------------------------------------------- -C PROBLEM, CAT. CODE IN INPUT NOT VALID; MAY EXIT WITH NEXT = -2 - NEXTX = -2 - PRINT 102, - $ COCRPT(LW2*11-LW1),COCRPT(LW2*12-LW1)(1:2),COCBUF(N)(1:2) - GO TO 99 -C----------------------------------------------------------------------- - 1000 CONTINUE -C 'M' IS THE WORD IN MOCRPT WHERE THE NO. OF LEVELS WILL BE WRITTEN - M = KATO(NCAT) -C WRITE THIS CATEGORY WORD PAIR OUT - MOCRPT(M) = LVLS - MOCRPT(M+1) = MO - N = N + 1 - I = 1 -C*********************************************************************** -C LOOP THROUGH ALL THE LEVELS IN THE CURRENT CATEGORY -C*********************************************************************** - DO 2000 L = 1,LVLS -C NDG IS NO. OF OUTPUT PARAMETERS PER LEVEL IN THIS CATEGORY - NDG = KATL(NCAT) -C----------------------------------------------------------------------- -C LOOP THROUGH ALL THE PARAMETERS IN THE CURRENT LEVEL -C----------------------------------------------------------------------- - DO 1800 K = 1,NDG -C 'LL' IS THE NUMBER OF INPUT CHARACTERS PER PARAMETER FOR THIS CATEGORY - LL = KATGL(K,NCAT) -C 'I' IS POINTER FOR BEGINNING BYTE IN C*10 WORD FOR NEXT PARAMETER -C 'J' IS POINTER FOR ENDING BYTE IN C*10 WORD FOR NEXT PARAMETER - J = I + LL - 1 - IF(J.GT.10) THEN -C COME HERE IF INPUT PARAMETER SPANS ACROSS TWO C*10 WORDS - HOLD(1:LL) = COCBUF(N)(I:10)//COCBUF(N+1)(1:J-10) - N = N + 1 - I = J - 9 - IF(I.GE.11) THEN - N = N + 1 - I = 1 - END IF - ELSE - HOLD(1:LL) = COCBUF(N)(I:J) - I = J + 1 - IF(I.GE.11) THEN - N = N + 1 - I = 1 - END IF - END IF -C KATGC IS AN INDICATOR FOR THE OUTPUT FORMAT OF EACH INPUT PARAMETER -C (=2 - REAL, =1 - INTEGER, =4 - CHARACTER*8) - IF(KATGC(K,NCAT).EQ.4) GO TO 1500 - IF(KATGC(K,NCAT).NE.1.AND.KATGC(K,NCAT).NE.2) THEN -C....................................................................... -C PROBLEM IN INTERNAL READ; MAY EXIT WITH NEXT = -2 - NEXTX = -2 - PRINT 104, COCRPT(LW2*11-LW1),COCRPT(LW2*12)(1:2) - GO TO 99 -C....................................................................... - END IF - IF(HOLD(1:LL).EQ.CNINES(1:LL)) THEN -C INPUT PARAMETER IS MISSING OR NOT APPLICABLE -- OUTPUT IT AS SUCH - IF(KATGC(K,NCAT).EQ.1) MOCRPT(MO) = IMSG - IF(KATGC(K,NCAT).EQ.2) ROCRPT(MO) = XMSG - GO TO 1750 - END IF - IF(LL.EQ.1) THEN -C INPUT PARAMETER CONSISTS OF ONE CHARACTER - IF(KATGC(K,NCAT).EQ.1) READ(HOLD(1:LL),10) MOCRPT(MO) - IF(KATGC(K,NCAT).EQ.2) READ(HOLD(1:LL),11) ROCRPT(MO) - ELSE IF(LL.EQ.2) THEN -C INPUT PARAMETER CONSISTS OF TWO CHARACTERS - IF(KATGC(K,NCAT).EQ.1) READ(HOLD(1:LL),20) MOCRPT(MO) - IF(KATGC(K,NCAT).EQ.2) READ(HOLD(1:LL),21) ROCRPT(MO) - ELSE IF(LL.EQ.3) THEN -C INPUT PARAMETER CONSISTS OF THREE CHARACTERS - IF(KATGC(K,NCAT).EQ.1) READ(HOLD(1:LL),30) MOCRPT(MO) - IF(KATGC(K,NCAT).EQ.2) READ(HOLD(1:LL),31) ROCRPT(MO) - ELSE IF(LL.EQ.4) THEN -C INPUT PARAMETER CONSISTS OF FOUR CHARACTERS - IF(KATGC(K,NCAT).EQ.1) READ(HOLD(1:LL),40) MOCRPT(MO) - IF(KATGC(K,NCAT).EQ.2) READ(HOLD(1:LL),41) ROCRPT(MO) - ELSE IF(LL.EQ.5) THEN -C INPUT PARAMETER CONSISTS OF FIVE CHARACTERS - IF(KATGC(K,NCAT).EQ.1) READ(HOLD(1:LL),50) MOCRPT(MO) - IF(KATGC(K,NCAT).EQ.2) READ(HOLD(1:LL),51) ROCRPT(MO) - ELSE IF(LL.EQ.6) THEN -C INPUT PARAMETER CONSISTS OF SIX CHARACTERS - IF(KATGC(K,NCAT).EQ.1) READ(HOLD(1:LL),60) MOCRPT(MO) - IF(KATGC(K,NCAT).EQ.2) READ(HOLD(1:LL),61) ROCRPT(MO) - ELSE IF(LL.EQ.7) THEN -C INPUT PARAMETER CONSISTS OF SEVEN CHARACTERS - IF(KATGC(K,NCAT).EQ.1) READ(HOLD(1:LL),70) MOCRPT(MO) - IF(KATGC(K,NCAT).EQ.2) READ(HOLD(1:LL),71) ROCRPT(MO) - ELSE -C....................................................................... -C INPUT PARAMETER CONSISTS OF MORE THAN SEVEN CHARACTERS (NOT PERMITTED) - NEXTX = -2 - PRINT 108, COCRPT(LW2*11-LW1),COCRPT(LW2*12-LW1)(1:2) - GO TO 99 -C....................................................................... - END IF - GO TO 1750 - 1500 CONTINUE -C....................................................................... -C OUTPUT CHARACTER (MARKER) PROCESSING COMES HERE - IF(LL.LT.4) THEN -C THERE ARE ONE, TWO OR THREE MARKERS IN THE INPUT WORD - COCRPT(LW2*MO-LW1)(1:4)=HOLD(1:LL)//BLANK(1:4-LL) - ELSE IF(LL.EQ.4) THEN -C THERE ARE FOUR MARKERS IN THE INPUT WORD - COCRPT(LW2*MO-LW1)(1:4) = HOLD(1:LL) - ELSE -C THERE ARE MORE THAN FOUR MARKERS IN THE INPUT WORD - IP = 1 - 1610 CONTINUE - JP = IP + 3 - IF(JP.LT.LL) THEN -C FILL FIRST FOUR MARKERS TO OUTPUT WORD - COCRPT(LW2*MO-LW1)(1:4) = HOLD(IP:JP) - MO = MO + 1 - IP = JP + 1 - GO TO 1610 - ELSE IF(JP.EQ.LL) THEN -C FILL FOUR REMAINING MARKERS TO NEXT OUTPUT WORD - COCRPT(LW2*MO-LW1)(1:4) = HOLD(IP:JP) - ELSE -C FILL ONE, TWO, OR THREE REMAINING MARKERS TO NEXT OUTPUT WORD - COCRPT(LW2*MO-LW1)(1:4) = HOLD(IP:LL)//BLANK(1:JP-LL) - END IF - END IF -C....................................................................... - 1750 CONTINUE - MO = MO + 1 - 1800 CONTINUE -C----------------------------------------------------------------------- - 2000 CONTINUE -C*********************************************************************** - IF(I.GT.1) N = N + 1 - IF(N-NEXTO.NE.NWDSC) THEN -C----------------------------------------------------------------------- -C PROBLEM, REL. LOCATION OF NEXT CAT. NOT WHAT'S EXPECTED; MAY EXIT -C WITH NEXT = -3 -C ERROR - RELATIVE LOCATION OF NEXT CATEGORY NOT WHAT'S EXPECTED - NEXTX = -3 - PRINT 105, COCRPT(LW2*11-LW1),COCRPT(LW2*12-LW1)(1:2), - $ KAT(NCAT),N-NEXTO-1, - $ NWDSC-1 - GO TO 99 -C----------------------------------------------------------------------- - END IF -C GO ON TO NEXT CATEGORY - GO TO 700 -C----------------------------------------------------------------------- -C ALL OF THE PROBLEM REPORTS END UP HERE -- ATTEMPT TO MOVE AHEAD TO -C NEXT REPORT, IF NOT POSSIBLE THEN EXIT WITH NEXT = -2 OR -3 MEANING -C THE REST OF THE RECORD IS BAD, GO ON TO NEXT RECORD - 99 CONTINUE - DO 98 I = 1,644 - N = N + 1 - IF(N.GT.644) GO TO 97 - IF(COCBUF(N).EQ.'END RECORD') GO TO 97 - IF(COCBUF(N).EQ.'END REPORT') THEN -C WE'VE MADE IT TO THE END OF THIS PROBLEM REPORT - START OVER WITH -C NEXT ONE - PRINT 106 - NEXT = N * 10 - GO TO 7000 - END IF - 98 CONTINUE - 97 CONTINUE -C COULDN'T GET TO THE END OF THIS PROBLEM REPORT - RETURN WITH ORIGINAL -C NEXT VALUE (-2 OR -3) MEANING USER MUST GO ON TO NEXT RECORD - NEXT = NEXTX - PRINT 107, NEXT - MWORDS = MO - 1 - DO 1002 I =1, MWORDS - LOCRPT(I) = MOCRPT(I) - 1002 CONTINUE - RETURN -C----------------------------------------------------------------------- - 10 FORMAT(I1) - 11 FORMAT(F1.0) - 20 FORMAT(I2) - 21 FORMAT(F2.0) - 30 FORMAT(I3) - 31 FORMAT(F3.0) - 40 FORMAT(I4) - 41 FORMAT(F4.0) - 50 FORMAT(I5) - 51 FORMAT(F5.0) - 60 FORMAT(I6) - 61 FORMAT(F6.0) - 70 FORMAT(I7) - 71 FORMAT(F7.0) - 101 FORMAT(/' *** W3FI64 ERROR- REPORT: ',A4,A2,'; ACTUAL NO. 10-CHAR' - $,' WORDS:',I10,' NOT EQUAL TO VALUE READ IN WITH REPORT:',I10/6X, - $ '- MAY BE DUE TO INTERNAL READ PROBLEM ASSOC. W/ EITHER ORIG. ', - $ 'PACKING OR TRANSFER OF FILE RESULTING IN UNPROCESSABLE INFO.'/6X - $,'- WILL ATTEMPT TO MOVE AHEAD TO NEXT REPORT, IF NOT POSSIBLE ', - $ 'WILL EXIT RECORD WITH NEXT = -3'/) - 102 FORMAT(/' *** W3FI64 ERROR- REPORT: ',A4,A2,'; PACKED CATEGORY ' - $,'CODE: ',A2,' IS NOT A VALID O.N. 29 CATEGORY'/6X, - $ '- MAY BE DUE TO INTERNAL READ PROBLEM ASSOC. W/ EITHER ORIG. ', - $ 'PACKING OR TRANSFER OF FILE RESULTING IN UNPROCESSABLE INFO.'/6X - $,'- WILL ATTEMPT TO MOVE AHEAD TO NEXT REPORT, IF NOT POSSIBLE ', - $ 'WILL EXIT RECORD WITH NEXT = -2'/) - 104 FORMAT(/' *** W3FI64 ERROR- REPORT: ',A4,A2,'; INTERNAL READ ', - $ 'PROBLEM'/6X,'- EITHER ORIGINAL PACKING OF FILE OR TRANSFER ', - $ 'OF FILE HAS RESULTED IN UNPROCESSABLE INFORMATION'/6X, - $ '- WILL ATTEMPT TO MOVE AHEAD TO NEXT REPORT, IF NOT POSSIBLE ', - $ 'WILL EXIT RECORD WITH NEXT = -2'/) - 105 FORMAT(/' *** W3FI64 ERROR- REPORT: ',A4,A2,'; ACTUAL NO. 10-CHAR' - $,' WORDS IN CAT. ',A2,',',I10,' .NE. TO VALUE READ IN WITH ', - $ 'REPORT:',I10/6X, - $ '- MAY BE DUE TO INTERNAL READ PROBLEM ASSOC. W/ EITHER ORIG. ', - $ 'PACKING OR TRANSFER OF FILE RESULTING IN UNPROCESSABLE INFO.'/6X - $,'- WILL ATTEMPT TO MOVE AHEAD TO NEXT REPORT, IF NOT POSSIBLE ', - $ 'WILL EXIT RECORD WITH NEXT = -3'/) - 106 FORMAT(/' +++ IT WAS POSSIBLE TO MOVE TO NEXT REPORT IN THIS ', - $ 'RECORD -- CONTINUE WITH THE UNPACKING OF THIS NEW REPORT'/) - 107 FORMAT(/' *** IT WAS NOT POSSIBLE TO MOVE TO NEXT REPORT IN THIS', - $ ' RECORD -- MUST EXIT THIS RECORD WITH NEXT =',I3/) - 108 FORMAT(/' *** W3FI64 ERROR- REPORT: ',A4,A2,'; AN INPUT ', - $ 'PARAMETER CONSISTS OF MORE THAN SEVEN CHARACTERS'/6X, - $ '- MAY BE DUE TO INTERNAL READ PROBLEM ASSOC. W/ EITHER ORIG. ', - $ 'PACKING OR TRANSFER OF FILE RESULTING IN UNPROCESSABLE INFO.'/6X - $,'- WILL ATTEMPT TO MOVE AHEAD TO NEXT REPORT, IF NOT POSSIBLE ', - $ 'WILL EXIT RECORD WITH NEXT = -2'/) - 109 FORMAT(/' *** W3FI64 ERROR- RECORD ',I4,' DOES NOT END WITH ', - $ '"END RECORD" BUT INSTEAD CONTAINS "X" FILLERS AFTER LAST ', - $ 'REPORT IN RECORD'/6X,'- WILL EXIT RECORD WITH NEXT = -1, NO ', - $ 'REPORTS SHOULD BE LOST'/) - END diff --git a/external/w3nco/v2.0.6/src/w3fi68.f b/external/w3nco/v2.0.6/src/w3fi68.f deleted file mode 100644 index 03a7ec3be..000000000 --- a/external/w3nco/v2.0.6/src/w3fi68.f +++ /dev/null @@ -1,184 +0,0 @@ - SUBROUTINE W3FI68 (ID, PDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI68 CONVERT 25 WORD ARRAY TO GRIB PDS -C PRGMMR: R.E.JONES ORG: W/NMC42 DATE: 91-05-14 -C -C ABSTRACT: CONVERTS AN ARRAY OF 25, OR 27 INTEGER WORDS INTO A -C GRIB PRODUCT DEFINITION SECTION (PDS) OF 28 BYTES , OR 30 BYTES. -C IF PDS BYTES > 30, THEY ARE SET TO ZERO. -C -C PROGRAM HISTORY LOG: -C 91-05-08 R.E.JONES -C 92-09-25 R.E.JONES CHANGE TO 25 WORDS OF INPUT, LEVEL -C CAN BE IN TWO WORDS. (10,11) -C 93-01-08 R.E.JONES CHANGE FOR TIME RANGE INDICATOR IF 10, -C STORE TIME P1 IN PDS BYTES 19-20. -C 93-01-26 R.E.JONES CORRECTION FOR FIXED HEIGHT ABOVE -C GROUND LEVEL -C 93-03-29 R.E.JONES ADD SAVE STATEMENT -C 93-06-24 CAVANOUGH MODIFIED PROGRAM TO ALLOW FOR GENERATION -C OF PDS GREATER THAN 28 BYTES (THE DESIRED -C PDS SIZE IS IN ID(1). -C 93-09-30 FARLEY CHANGE TO ALLOW FOR SUBCENTER ID; PUT -C ID(24) INTO PDS(26). -C 93-10-12 R.E.JONES CHANGES FOR ON388 REV. OCT 9,1993, NEW -C LEVELS 125, 200, 201. -C 94-02-23 R.E.JONES TAKE OUT SBYTES, REPLACE WITH DO LOOP -C 94-04-14 R.E.JONES CHANGES FOR ON388 REV. MAR 24,1994, NEW -C LEVELS 115,116. -C 94-12-04 R.E.JONES CHANGE TO ADD ID WORDS 26, 27 FOR PDS -C BYTES 29 AND 30. -C 95-09-07 R.E.JONES CHANGE FOR NEW LEVEL 117, 119. -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-06-30 EBISUZAKI LINUX PORT -C 2001-06-05 GILBERT Changed fortran intrinsic function OR() to -C f90 standard intrinsic IOR(). -C 2003-02-25 IREDELL RECOGNIZE LEVEL TYPE 126 -C 2005-05-06 D.C.STOKES RECOGNIZE LEVEL TYPES 235, 237, 238 -C -C USAGE: CALL W3FI68 (ID, PDS) -C INPUT ARGUMENT LIST: -C ID - 25, 27 WORD INTEGER ARRAY -C OUTPUT ARGUMENT LIST: -C PDS - 28 30, OR GREATER CHARACTER PDS FOR EDITION 1 -C -C REMARKS: LAYOUT OF 'ID' ARRAY: -C ID(1) = NUMBER OF BYTES IN PRODUCT DEFINITION SECTION (PDS) -C ID(2) = PARAMETER TABLE VERSION NUMBER -C ID(3) = IDENTIFICATION OF ORIGINATING CENTER -C ID(4) = MODEL IDENTIFICATION (ALLOCATED BY ORIGINATING CENTER) -C ID(5) = GRID IDENTIFICATION -C ID(6) = 0 IF NO GDS SECTION, 1 IF GDS SECTION IS INCLUDED -C ID(7) = 0 IF NO BMS SECTION, 1 IF BMS SECTION IS INCLUDED -C ID(8) = INDICATOR OF PARAMETER AND UNITS (TABLE 2) -C ID(9) = INDICATOR OF TYPE OF LEVEL (TABLE 3) -C ID(10) = VALUE 1 OF LEVEL (0 FOR 1-100,102,103,105,107 -C 109,111,113,115,117,119,125,126,160,200,201, -C 235,237,238 -C LEVEL IS IN ID WORD 11) -C ID(11) = VALUE 2 OF LEVEL -C ID(12) = YEAR OF CENTURY -C ID(13) = MONTH OF YEAR -C ID(14) = DAY OF MONTH -C ID(15) = HOUR OF DAY -C ID(16) = MINUTE OF HOUR (IN MOST CASES SET TO 0) -C ID(17) = FCST TIME UNIT -C ID(18) = P1 PERIOD OF TIME -C ID(19) = P2 PERIOD OF TIME -C ID(20) = TIME RANGE INDICATOR -C ID(21) = NUMBER INCLUDED IN AVERAGE -C ID(22) = NUMBER MISSING FROM AVERAGES -C ID(23) = CENTURY (20, CHANGE TO 21 ON JAN. 1, 2001) -C ID(24) = SUBCENTER IDENTIFICATION -C ID(25) = SCALING POWER OF 10 -C ID(26) = FLAG BYTE, 8 ON/OFF FLAGS -C BIT NUMBER VALUE ID(26) DEFINITION -C 1 0 0 FULL FCST FIELD -C 1 128 FCST ERROR FIELD -C 2 0 0 ORIGINAL FCST FIELD -C 1 64 BIAS CORRECTED FCST FIELD -C 3 0 0 ORIGINAL RESOLUTION RETAINED -C 1 32 SMOOTHED FIELD -C NOTE: ID(26) CAN BE THE SUM OF BITS 1, 2, 3. -C BITS 4-8 NOT USED, SET TO ZERO -C IF ID(1) IS 28, YOU DO NOT NEED ID(26) AND ID(27). -C ID(27) = UNUSED, SET TO 0 SO PDS BYTE 30 IS SET TO ZERO. -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: SiliconGraphics 3.5 FORTRAN 77 -C MACHINE: SiliconGraphics IRIS-4D/25, 35, INDIGO, Indy -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916/256, J916/2048 -C -C$$$ -C - INTEGER ID(*) -C - CHARACTER * 1 PDS(*) -C - PDS(1) = CHAR(MOD(ID(1)/65536,256)) - PDS(2) = CHAR(MOD(ID(1)/256,256)) - PDS(3) = CHAR(MOD(ID(1),256)) - PDS(4) = CHAR(ID(2)) - PDS(5) = CHAR(ID(3)) - PDS(6) = CHAR(ID(4)) - PDS(7) = CHAR(ID(5)) - i = 0 - if (ID(6).ne.0) i = i + 128 - if (ID(7).ne.0) i = i + 64 - PDS(8) = char(i) - - PDS(9) = CHAR(ID(8)) - PDS(10) = CHAR(ID(9)) - I9 = ID(9) -C -C TEST TYPE OF LEVEL TO SEE IF LEVEL IS IN TWO -C WORDS OR ONE -C - IF ((I9.GE.1.AND.I9.LE.100).OR.I9.EQ.102.OR. - & I9.EQ.103.OR.I9.EQ.105.OR.I9.EQ.107.OR. - & I9.EQ.109.OR.I9.EQ.111.OR.I9.EQ.113.OR. - & I9.EQ.115.OR.I9.EQ.117.OR.I9.EQ.119.OR. - & I9.EQ.125.OR.I9.EQ.126.OR.I9.EQ.160.OR. - & I9.EQ.200.OR.I9.EQ.201.OR.I9.EQ.235.OR. - & I9.EQ.237.OR.I9.EQ.238) THEN - LEVEL = ID(11) - IF (LEVEL.LT.0) THEN - LEVEL = - LEVEL - LEVEL = IOR(LEVEL,32768) - END IF - PDS(11) = CHAR(MOD(LEVEL/256,256)) - PDS(12) = CHAR(MOD(LEVEL,256)) - ELSE - PDS(11) = CHAR(ID(10)) - PDS(12) = CHAR(ID(11)) - END IF - PDS(13) = CHAR(ID(12)) - PDS(14) = CHAR(ID(13)) - PDS(15) = CHAR(ID(14)) - PDS(16) = CHAR(ID(15)) - PDS(17) = CHAR(ID(16)) - PDS(18) = CHAR(ID(17)) -C -C TEST TIME RANGE INDICATOR (PDS BYTE 21) FOR 10 -C IF SO PUT TIME P1 IN PDS BYTES 19-20. -C - IF (ID(20).EQ.10) THEN - PDS(19) = CHAR(MOD(ID(18)/256,256)) - PDS(20) = CHAR(MOD(ID(18),256)) - ELSE - PDS(19) = CHAR(ID(18)) - PDS(20) = CHAR(ID(19)) - END IF - PDS(21) = CHAR(ID(20)) - PDS(22) = CHAR(MOD(ID(21)/256,256)) - PDS(23) = CHAR(MOD(ID(21),256)) - PDS(24) = CHAR(ID(22)) - PDS(25) = CHAR(ID(23)) - PDS(26) = CHAR(ID(24)) - ISCALE = ID(25) - IF (ISCALE.LT.0) THEN - ISCALE = -ISCALE - ISCALE = IOR(ISCALE,32768) - END IF - PDS(27) = CHAR(MOD(ISCALE/256,256)) - PDS(28) = CHAR(MOD(ISCALE ,256)) - IF (ID(1).GT.28) THEN - PDS(29) = CHAR(ID(26)) - PDS(30) = CHAR(ID(27)) - END IF -C -C SET PDS 31-?? TO ZERO -C - IF (ID(1).GT.30) THEN - K = ID(1) - DO I = 31,K - PDS(I) = CHAR(0) - END DO - END IF -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi69.f b/external/w3nco/v2.0.6/src/w3fi69.f deleted file mode 100644 index 877867c67..000000000 --- a/external/w3nco/v2.0.6/src/w3fi69.f +++ /dev/null @@ -1,149 +0,0 @@ - SUBROUTINE W3FI69 (PDS, ID) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI69 CONVERT PDS TO 25, OR 27 WORD ARRAY -C PRGMMR: R.E.JONES ORG: W/NMC42 DATE: 91-05-14 -C -C ABSTRACT: CONVERTS AN EDITION 1 GRIB PRODUCE DEFINITION SECTION (PDS) -C TO A 25, OR 27 WORD INTEGER ARRAY. -C -C PROGRAM HISTORY LOG: -C 91-05-14 R.E.JONES -C 92-09-25 R.E.JONES CHANGE LEVEL TO USE ONE OR TWO WORDS -C 93-01-08 R.E.JONES CHANGE FOR TIME RANGE INDICATOR IF 10 -C 93-03-29 R.E.JONES ADD SAVE STATEMENT -C 93-10-21 R.E.JONES CHANGES FOR ON388 REV. OCT 9,1993, NEW -C LEVELS 125, 200, 201. -C 94-04-14 R.E.JONES CHANGES FOR ON388 REV. MAR 24,1994, NEW -C LEVELS 115, 116. -C 94-12-04 R.E.JONES CHANGES FOR 27 WORD INTEGER ARRAY IF -C PDS IS GREATER THAN 28 BYTES. -C 95-09-07 R.E.JONES CHANGES FOR LEVEL 117, 119. -C 98-12-21 Gilbert Replaced Function ICHAR with mova2i. -C -C USAGE: CALL W3FI69 (PDS, ID) -C INPUT ARGUMENT LIST: -C PDS - 28 TO 100 CHARACTER PRODUCT DEFINITION SECTION -C (PDS) -C OUTPUT ARGUMENT LIST: -C ID - 25, OR 27 WORD INTEGER ARRAY -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: SiliconGraphics 3.5 FORTRAN 77 -C MACHINE: SiliconGraphics IRIS-4D/25, 35, INDIGO, Indy -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916/256, J916/2048 -C -C$$$ -C - INTEGER ID(*) -C - CHARACTER * 1 PDS(*) -C - SAVE -C -C ID(1) = NUMBER OF BYTES IN PDS -C ID(2) = PARAMETER TABLE VERSION NUMBER -C ID(3) = IDENTIFICATION OF ORIGINATING CENTER -C ID(4) = MODEL IDENTIFICATION (ALLOCATED BY ORIGINATING CENTER) -C ID(5) = GRID IDENTIFICATION -C ID(6) = 0 IF NO GDS SECTION, 1 IF GDS SECTION IS INCLUDED -C ID(7) = 0 IF NO BMS SECTION, 1 IF BMS SECTION IS INCLUDED -C ID(8) = INDICATOR OF PARAMETER AND UNITS -C ID(9) = INDICATOR OF TYPE OF LEVEL OR LAYER -C ID(10) = LEVEL 1 -C ID(11) = LEVEL 2 -C ID(12) = YEAR OF CENTURY -C ID(13) = MONTH OF YEAR -C ID(14) = DAY OF MONTH -C ID(15) = HOUR OF DAY -C ID(16) = MINUTE OF HOUR (IN MOST CASES SET TO 0) -C ID(17) = FCST TIME UNIT -C ID(18) = P1 PERIOD OF TIME -C ID(19) = P2 PERIOD OF TIME -C ID(20) = TIME RANGE INDICATOR -C ID(21) = NUMBER INCLUDED IN AVERAGE -C ID(22) = NUMBER MISSING FROM AVERAGES OR ACCUMULATIONS -C ID(23) = CENTURY -C ID(24) = IDENTIFICATION OF SUB-CENTER (TABLE 0 - PART 2) -C ID(25) = SCALING POWER OF 10 -C ID(26) = FLAG BYTE, 8 ON/OFF FLAGS -C BIT NUMBER VALUE ID(26) DEFINITION -C 1 0 0 FULL FCST FIELD -C 1 128 FCST ERROR FIELD -C 2 0 0 ORIGINAL FCST FIELD -C 1 64 BIAS CORRECTED FCST FIELD -C 3 0 0 ORIGINAL RESOLUTION RETAINED -C 1 32 SMOOTHED FIELD -C NOTE: ID(26) CAN BE THE SUM OF BITS 1, 2, 3. -C BITS 4-8 NOT USED, SET TO ZERO. -C IF ID(1) IS 28, YOU DO NOT NEED ID(26) AND ID(27). -C ID(27) = UNUSED, SET TO 0 SO PDS BYTE 30 IS SET TO ZERO.$ -C - ID(1) = mova2i(PDS(1)) * 65536 + mova2i(PDS(2)) * 256 + - & mova2i(PDS(3)) - ID(2) = mova2i(PDS(4)) - ID(3) = mova2i(PDS(5)) - ID(4) = mova2i(PDS(6)) - ID(5) = mova2i(PDS(7)) - ID(6) = IAND(ISHFT(mova2i(PDS(8)),-7),1) - ID(7) = IAND(ISHFT(mova2i(PDS(8)),-6),1) - ID(8) = mova2i(PDS(9)) - ID(9) = mova2i(PDS(10)) - I9 = mova2i(PDS(10)) -C -C TEST ID(9) FOR 1-100, 102,103, 105, 107, 109, -C 111,113,115,117,119,160,200,201, IF TRUE, SET ID(10) TO 0, -C AND STORE 16 BIT VALUE (BYTES 11 & 12) THE LEVEL IN ID(11). -C - IF ((I9.GE.1.AND.I9.LE.100).OR.I9.EQ.102.OR. - & I9.EQ.103.OR.I9.EQ.105.OR.I9.EQ.107.OR. - & I9.EQ.109.OR.I9.EQ.111.OR.I9.EQ.113.OR. - & I9.EQ.115.OR.I9.EQ.117.OR.I9.EQ.119.OR. - & I9.EQ.125.OR.I9.EQ.160.OR.I9.EQ.200.OR. - & I9.EQ.201) THEN - LEVEL = mova2i(PDS(11)) * 256 + mova2i(PDS(12)) - IF (IAND(LEVEL,32768).NE.0) THEN - LEVEL = -IAND(LEVEL,32767) - END IF - ID(10) = 0 - ID(11) = LEVEL - ELSE - ID(10) = mova2i(PDS(11)) - ID(11) = mova2i(PDS(12)) - END IF - ID(12) = mova2i(PDS(13)) - ID(13) = mova2i(PDS(14)) - ID(14) = mova2i(PDS(15)) - ID(15) = mova2i(PDS(16)) - ID(16) = mova2i(PDS(17)) - ID(17) = mova2i(PDS(18)) - ID(18) = mova2i(PDS(19)) - ID(19) = mova2i(PDS(20)) - ID(20) = mova2i(PDS(21)) -C -C IF TIME RANGE IDICATOR IS 10, P1 IS PACKED INTO -C PDS BYTES 19-20. PUT THEM IN P1 AND SET P2 TO ZERO. -C - IF (ID(20).EQ.10) THEN - ID(18) = ID(18) * 256 + ID(19) - ID(19) = 0 - END IF - ID(21) = mova2i(PDS(22)) * 256 + mova2i(PDS(23)) - ID(22) = mova2i(PDS(24)) - ID(23) = mova2i(PDS(25)) - ID(24) = mova2i(PDS(26)) - ISCALE = mova2i(PDS(27)) * 256 + mova2i(PDS(28)) - IF (IAND(ISCALE,32768).NE.0) THEN - ISCALE = -IAND(ISCALE,32767) - END IF - ID(25) = ISCALE - IF (ID(1).GT.28) THEN - ID(26) = mova2i(PDS(29)) - ID(27) = mova2i(PDS(30)) - END IF -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi71.f b/external/w3nco/v2.0.6/src/w3fi71.f deleted file mode 100644 index 8205a2b67..000000000 --- a/external/w3nco/v2.0.6/src/w3fi71.f +++ /dev/null @@ -1,1769 +0,0 @@ - SUBROUTINE W3FI71 (IGRID, IGDS, IERR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI71 MAKE ARRAY USED BY GRIB PACKER FOR GDS -C PRGMMR: R.E.JONES ORG: W/NMC42 DATE: 93-03-26 -C -C ABSTRACT: W3FI71 MAKES A 18, 37, 55, 64, OR 91 WORD INTEGER ARRAY -C USED BY W3FI72 GRIB PACKER TO MAKE THE GRID DESCRIPTION SECTION -C (GDS) - SECTION 2. -C -C PROGRAM HISTORY LOG: -C 92-02-21 R.E.JONES -C 92-07-01 M. FARLEY ADDED REMARKS FOR 'IGDS' ARRAY ELEMENTS. -C ADDED LAMBERT CONFORMAL GRIDS AND ENLARGED -C IDGS ARRAY FROM 14 TO 18 WORDS. -C 92-10-03 R.E.JONES ADDED CORRECTIONS TO AWIPS GRIB TABLES -C 92-10-16 R.E.JONES ADD GAUSSIAN GRID 126 TO TABLES -C 92-10-18 R.E.JONES CORRECTIONS TO LAMBERT CONFORMAL TABLES -C AND OTHER TABLES -C 92-10-19 R.E.JONES ADD GAUSSIAN GRID 98 TO TABLES -C 93-01-25 R.E.JONES ADD ON84 GRIDS 87, 106, 107 TO TABLES -C 93-03-10 R.E.JONES ADD ON84 GRIDS 1, 55, 56 TO TABLES -C 93-03-26 R.E.JONES ADD GRIB GRIDS 2, 3 TO TABLES -C 93-03-29 R.E.JONES ADD SAVE STATEMENT -C 93-06-15 R.E.JONES ADD GRIB GRIDS 37 TO 44 TO TABLES -C 93-09-29 R.E.JONES GAUSSIAN GRID DOCUMENT NOT CORRECT, -C W3FI74 WILL BE CHANGED TO AGREE WITH -C IT. GAUSSIAN GRID 98 TABLE HAS WRONG -C VALUE. -C 93-10-12 R.E.JONES CHANGES FOR ON388 REV. OCT 8,1993 FOR -C GRID 204, 208. -C 93-10-13 R.E.JONES CORRECTION FOR GRIDS 37-44, BYTES 7-8, -C 24-25 SET TO ALL BITS 1 FOR MISSING. -C 93-11-23 R.E.JONES ADD GRIDS 90-93 FOR ETA MODEL -C ADD GRID 4 FOR 720*361 .5 DEG. GRID -C 94-04-12 R.E.JONES CORRECTION FOR GRID 28 -C 94-06-01 R.E.JONES ADD GRID 45, 288*145 1.25 DEG. GRID -C 94-06-22 R.E.JONES ADD GRIDS 94, 95 FOR ETA MODEL -C 95-04-11 R.E.JONES ADD GRIDS 96, 97 FOR ETA MODEL -C 95-05-19 R.E.JONES ADD FROM 20 KM ETA MODEL AWIPS GRID 215 -C 95-10-19 R.E.JONES ADD FROM 20 KM ETA MODEL ALASKA GRID 216 -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 96-05-08 IREDELL CORRECT FIRST LATITUDE FOR GRIDS 27 AND 28 -C 96-07-02 R.E.JONES ADD FROM 10 KM ETA MODEL OLYMPIC GRID 218 -C 96-07-02 R.E.JONES ADD 196 FOR ETA MODEL -C 96-08-15 R.E.JONES ADD O.N. 84 GRID 8 AND 53 AS GRIB GRID 8 -C AND 53 -C 96-11-29 R.E.JONES CORRECTION TO TABLES FOR GRID 21-26, 61-64 -C 97-01-31 IREDELL CORRECT FIRST LATITUDE FOR GRID 30 -C 97-10-20 IREDELL CORRECT LAST LONGITUDE FOR GRID 98 -C 98-07-07 Gilbert Add grids 217 and 219 through 235 -C 98-09-21 BALDWIN ADD GRIDS 190, 192 FOR ETA MODEL -C 99-01-20 BALDWIN ADD GRIDS 236, 237 -C 99-08-18 IREDELL ADD GRID 170 -C 01-03-08 ROGERS CHANGED ETA GRIDS 90-97, ADDED ETA GRIDS -C 194, 198. ADDED AWIPS GRIDS 241,242,243, -C 245, 246, 247, 248, AND 250 -C 01-03-19 VUONG ADDED AWIPS GRIDS 238,239,240, AND 244 -C 01-04-02 VUONG CORRECT LAST LONGITUDE FOR GRID 225 -C 01-05-03 ROGERS ADDED GRID 249 -C 01-10-10 ROGERS REDEFINED 218 FOR 12-KM ETA -C REDEFINED GRID 192 FOR NEW 32-KM ETA GRID -C 02-03-27 VUONG ADDED RSAS GRID 88 AND AWIPS GRIDS 251 AND 252 -C 02-08-06 ROGERS REDEFINED GRIDS 90-93,97,194,245-250 FOR THE -C 8KM HI-RES-WINDOW MODEL AND ADD AWIPS GRID 253 -C 2003-06-30 GILBERT ADDED GRIDS 145 and 146 for CMAQ -C and GRID 175 for AWIPS over GUAM. -C 2003-07-08 VUONG CORRECTED LATITUDE FOR GRID 253 AND 170, ADD GRID -C 110, 127, 171 AND 172 -C 2004-08-05 VUONG CORRECTED LATITUDE FOR GRID 253 -C 2004-09-01 GILBERT Corrected the orientation and projection center flag -C for southern hemisphere grids 28, 172, 220 and 224 -C 2004-09-02 VUONG ADDED GRIDS 147, 148, 173 AND 254 -C 2005-01-04 COOKE Added grids 160, 161 and corrected longitude of orientation for grid 172 -C 2005-03-03 VUONG MOVED GRID 170 TO GRID 174 AND ADD GRID 170 -C 2005-03-21 VUONG ADDED GRIDS 130 -C 2005-09-12 VUONG ADDED GRIDS 163 -C 2006-10-27 VUONG CORRECTED X AND Y-DIRECTION GRID LENGTH FOR GRIDS 252 -C 2006-11-16 VUONG CHANGED THE LONGITUDE FROM NEGATIVE TO POSITIVE DEGREE FOR GRIDS 252 -C 2006-12-12 VUONG CHANGED DATA REPRESENTATION TYPE (OCTET 6) FROM 0 TO 1 FOR GRID 254 -C ADD GRID 120 (CURVILINEAR ORTHOGONAL GRID) -C 2006-12-27 VUONG CORRECTED THE LAT/LON DIRECTION INCREMENT FOR GRID 160 -C 2007-03-21 VUONG CORRECTED THE LAT/LON DIRECTION INCREMENT, RESOULUTION, -C SCANNING MODE FOR GRID 235 AND GRID TYPE 204 FOR GRID 120 -C 2007-04-24 VUONG CORRECTED THE LAT/LON DIRECTION INCREMENT, RESOULUTION, -C FOR GRIDS (219,173,220,171,233,238,239,244,253) AND ADDED -C GRID 176. -C 2007-06-11 VUONG ADDED NEW GRIDS (11,12,13,14,15,16,18,122,123,124,125,138 -C 180, 181, 182, 183) AND CORRECTED THE LAT/LON DIRECTION -C INCREMENT FOR GRID 240. -C 2007-11-06 VUONG CORRECTED THE SCANNING MODE FOR GRIDS (11,12,13,14,15,16,18) -C CHANGED GRID 198 FROM ARAKAWA STAGGERED E-GRID TO POLAR -C STEREOGRAPHIC GRID ADDED NEW GRID 10, 99, 150, 151, 197 -C 2008-01-17 VUONG ADDED NEW GRID 195 AND CHANGED GRID 196 (ARAKAWA-E TO MERCATOR) -C 2010-02-15 VUONG MODIFIED TO CORRECT LATITUDE FOR GRID 151 AND ADDED -C 2010-06-01 VUONG MODIFIED TO CORRECT LATITUDE AND LONGITUDE FOR GRID 196 -C 2010-08-05 VUONG ADDED NEW GRID 184, 199, 83 AND -C REDEFINED GRID 90 FOR NEW RTMA CONUS 1.27-KM -C REDEFINED GRID 91 FOR NEW RTMA ALASKA 2.976-KM -C REDEFINED GRID 92 FOR NEW RTMA ALASKA 1.488-KM -C 2010-09-08 ROGERS CHANGED GRID 94 TO ALASKA 6KM STAGGERED B-GRID -C CHANGED GRID 95 TO PUERTO RICO 3KM STAGGERED B-GRID -C CHANGED GRID 96 TO HAWAII 3KM STAGGERED B-GRID -C CHANGED GRID 96 TO HAWAII 3KM STAGGERED B-GRID -C CHANGED GRID 97 TO CONUS 4KM STAGGERED B-GRID -C CHANGED GRID 99 TO NAM 12KM STAGGERED B-GRID -C ADDED GRID 179 (12 KM POLAR STEREOGRAPHIC OVER NORTH AMERICA) -C CHANGED GRID 194 TO 3KM MERCATOR GRID OVER PUERTO RICO -C CORRECTED LATITUDE OF SW CORNER POINT OF GRID 151 -C 2011-10-12 VUONG ADDED GRID 129, 187, 188, 189 and 193 -C 2012-04-16 VUONG ADDED GRID 132, 200 -C 2012-11-07 VUONG CORRECTED GRID 174 FOR RES. AND COMP. FLAG SET TO 128 -C -C USAGE: CALL W3FI71 (IGRID, IGDS, IERR) -C INPUT ARGUMENT LIST: -C IGRID - GRIB GRID NUMBER, OR OFFICE NOTE 84 GRID NUMBER -C -C OUTPUT ARGUMENT LIST: -C IGDS - 18, 37, 55, 64, OR 91 WORD INTEGER ARRAY WITH -C INFORMATION TO MAKE A GRIB GRID DESCRIPTION SECTION. -C IERR - 0 CORRECT EXIT -C 1 GRID TYPE IN IGRID IS NOT IN TABLE -C -C REMARKS: -C 1) OFFICE NOTE GRID TYPE 26 IS 6 IN GRIB, 26 IS AN -C INTERNATIONAL EXCHANGE GRID. -C -C 2) VALUES RETURNED IN 18, 37, 55, 64, OR 91 WORD INTEGER ARRAY -C IGDS VARY DEPENDING ON GRID REPRESENTATION TYPE. -C -C LAT/LON GRID: -C IGDS( 1) = NUMBER OF VERTICAL COORDINATES -C IGDS( 2) = PV, PL OR 255 -C IGDS( 3) = DATA REPRESENTATION TYPE (CODE TABLE 6) -C IGDS( 4) = NO. OF POINTS ALONG A LATITUDE -C IGDS( 5) = NO. OF POINTS ALONG A LONGITUDE MERIDIAN -C IGDS( 6) = LATITUDE OF ORIGIN (SOUTH - IVE) -C IGDS( 7) = LONGITUDE OF ORIGIN (WEST -IVE) -C IGDS( 8) = RESOLUTION FLAG (CODE TABLE 7) -C IGDS( 9) = LATITUDE OF EXTREME POINT (SOUTH - IVE) -C IGDS(10) = LONGITUDE OF EXTREME POINT (WEST - IVE) -C IGDS(11) = LATITUDE INCREMENT -C IGDS(12) = LONGITUDE INCREMENT -C IGDS(13) = SCANNING MODE FLAGS (CODE TABLE 8) -C IGDS(14) = ... THROUGH ... -C IGDS(18) = ... NOT USED FOR THIS GRID -C IGDS(19) - IGDS(91) FOR GRIDS 37-44, NUMBER OF POINTS -C IN EACH OF 73 ROWS. -C -C GAUSSIAN GRID: -C IGDS( 1) = ... THROUGH ... -C IGDS(10) = ... SAME AS LAT/LON GRID -C IGDS(11) = NUMBER OF LATITUDE LINES BETWEEN A POLE -C AND THE EQUATOR -C IGDS(12) = LONGITUDE INCREMENT -C IGDS(13) = SCANNING MODE FLAGS (CODE TABLE 8) -C IGDS(14) = ... THROUGH ... -C IGDS(18) = ... NOT USED FOR THIS GRID -C -C SPHERICAL HARMONICS: -C IGDS( 1) = NUMBER OF VERTICAL COORDINATES -C IGDS( 2) = PV, PL OR 255 -C IGDS( 3) = DATA REPRESENTATION TYPE (CODE TABLE 6) -C IGDS( 4) = J - PENTAGONAL RESOLUTION PARAMETER -C IGDS( 5) = K - PENTAGONAL RESOLUTION PARAMETER -C IGDS( 6) = M - PENTAGONAL RESOLUTION PARAMETER -C IGDS( 7) = REPRESENTATION TYPE (CODE TABLE 9) -C IGDS( 8) = REPRESENTATION MODE (CODE TABLE 10) -C IGDS( 9) = ... THROUGH ... -C IGDS(18) = ... NOT USED FOR THIS GRID -C -C POLAR STEREOGRAPHIC: -C IGDS( 1) = NUMBER OF VERTICAL COORDINATES -C IGDS( 2) = PV, PL OR 255 -C IGDS( 3) = DATA REPRESENTATION TYPE (CODE TABLE 6) -C IGDS( 4) = NO. OF POINTS ALONG X-AXIS -C IGDS( 5) = NO. OF POINTS ALONG Y-AXIS -C IGDS( 6) = LATITUDE OF ORIGIN (SOUTH -IVE) -C IGDS( 7) = LONGITUTE OF ORIGIN (WEST -IVE) -C IGDS( 8) = RESOLUTION FLAG (CODE TABLE 7) -C IGDS( 9) = LONGITUDE OF MERIDIAN PARALLEL TO Y-AXIS -C IGDS(10) = X-DIRECTION GRID LENGTH (INCREMENT) -C IGDS(11) = Y-DIRECTION GRID LENGTH (INCREMENT) -C IGDS(12) = PROJECTION CENTER FLAG (0=NORTH POLE ON PLANE, -C 1=SOUTH POLE ON PLANE, -C IGDS(13) = SCANNING MODE FLAGS (CODE TABLE 8) -C IGDS(14) = ... THROUGH ... -C IGDS(18) = .. NOT USED FOR THIS GRID -C -C MERCATOR: -C IGDS( 1) = ... THROUGH ... -C IGDS(12) = ... SAME AS LAT/LON GRID -C IGDS(13) = LATITUDE AT WHICH PROJECTION CYLINDER -C INTERSECTS EARTH -C IGDS(14) = SCANNING MODE FLAGS -C IGDS(15) = ... THROUGH ... -C IGDS(18) = .. NOT USED FOR THIS GRID -C -C LAMBERT CONFORMAL: -C IGDS( 1) = NUMBER OF VERTICAL COORDINATES -C IGDS( 2) = PV, PL OR 255 -C IGDS( 3) = DATA REPRESENTATION TYPE (CODE TABLE 6) -C IGDS( 4) = NO. OF POINTS ALONG X-AXIS -C IGDS( 5) = NO. OF POINTS ALONG Y-AXIS -C IGDS( 6) = LATITUDE OF ORIGIN (SOUTH -IVE) -C IGDS( 7) = LONGITUTE OF ORIGIN (WEST -IVE) -C IGDS( 8) = RESOLUTION FLAG (CODE TABLE 7) -C IGDS( 9) = LONGITUDE OF MERIDIAN PARALLEL TO Y-AXIS -C IGDS(10) = X-DIRECTION GRID LENGTH (INCREMENT) -C IGDS(11) = Y-DIRECTION GRID LENGTH (INCREMENT) -C IGDS(12) = PROJECTION CENTER FLAG (0=NORTH POLE ON PLANE, -C 1=SOUTH POLE ON PLANE, -C IGDS(13) = SCANNING MODE FLAGS (CODE TABLE 8) -C IGDS(14) = NOT USED -C IGDS(15) = FIRST LATITUDE FROM THE POLE AT WHICH THE -C SECANT CONE CUTS THE SPERICAL EARTH -C IGDS(16) = SECOND LATITUDE ... -C IGDS(17) = LATITUDE OF SOUTH POLE (MILLIDEGREES) -C IGDS(18) = LONGITUDE OF SOUTH POLE (MILLIDEGREES) -C -C ARAKAWA SEMI-STAGGERED E-GRID ON ROTATED LAT/LON GRID -C IGDS( 1) = NUMBER OF VERTICAL COORDINATES -C IGDS( 2) = PV, PL OR 255 -C IGDS( 3) = DATA REPRESENTATION TYPE (CODE TABLE 6) [201] -C IGDS( 4) = NI - TOTAL NUMBER OF ACTUAL DATA POINTS -C INCLUDED ON GRID -C IGDS( 5) = NJ - DUMMY SECOND DIMENSION; SET=1 -C IGDS( 6) = LA1 - LATITUDE OF FIRST GRID POINT -C IGDS( 7) = LO1 - LONGITUDE OF FIRST GRID POINT -C IGDS( 8) = RESOLUTION AND COMPONENT FLAG (CODE TABLE 7) -C IGDS( 9) = LA2 - NUMBER OF MASS POINTS ALONG -C SOUTHERNMOST ROW OF GRID -C IGDS(10) = LO2 - NUMBER OF ROWS IN EACH COLUMN -C IGDS(11) = DI - LONGITUDINAL DIRECTION INCREMENT -C IGDS(12) = DJ - LATITUDINAL DIRECTION INCREMENT -C IGDS(13) = SCANNING MODE FLAGS (CODE TABLE 8) -C IGDS(14) = ... THROUGH ... -C IGDS(18) = ... NOT USED FOR THIS GRID (SET TO ZERO) -C -C ARAKAWA FILLED E-GRID ON ROTATED LAT/LON GRID -C IGDS( 1) = NUMBER OF VERTICAL COORDINATES -C IGDS( 2) = PV, PL OR 255 -C IGDS( 3) = DATA REPRESENTATION TYPE (CODE TABLE 6) [202] -C IGDS( 4) = NI - TOTAL NUMBER OF ACTUAL DATA POINTS -C INCLUDED ON GRID -C IGDS( 5) = NJ - DUMMY SECOND DIMENTION; SET=1 -C IGDS( 6) = LA1 - LATITUDE LATITUDE OF FIRST GRID POINT -C IGDS( 7) = LO1 - LONGITUDE OF FIRST GRID POINT -C IGDS( 8) = RESOLUTION AND COMPONENT FLAG (CODE TABLE 7) -C IGDS( 9) = LA2 - NUMBER OF (ZONAL) POINTS IN EACH ROW -C IGDS(10) = LO2 - NUMBER OF (MERIDIONAL) POINTS IN EACH -C COLUMN -C IGDS(11) = DI - LONGITUDINAL DIRECTION INCREMENT -C IGDS(12) = DJ - LATITUDINAL DIRECTION INCREMENT -C IGDS(13) = SCANNING MODE FLAGS (CODE TABLE 8) -C IGDS(14) = ... THROUGH ... -C IGDS(18) = ... NOT USED FOR THIS GRID -C -C ARAKAWA STAGGERED E-GRID ON ROTATED LAT/LON GRID -C IGDS( 1) = NUMBER OF VERTICAL COORDINATES -C IGDS( 2) = PV, PL OR 255 -C IGDS( 3) = DATA REPRESENTATION TYPE (CODE TABLE 6) [203] -C IGDS( 4) = NI - NUMBER OF DATA POINTS IN EACH ROW -C IGDS( 5) = NJ - NUMBER OF ROWS -C IGDS( 6) = LA1 - LATITUDE OF FIRST GRID POINT -C IGDS( 7) = LO1 - LONGITUDE OF FIRST GRID POINT -C IGDS( 8) = RESOLUTION AND COMPONENT FLAG (CODE TABLE 7) -C IGDS( 9) = LA2 - CENTRAL LATITUDE -C IGDS(10) = LO2 - CENTRAL LONGTITUDE -C IGDS(11) = DI - LONGITUDINAL DIRECTION INCREMENT -C IGDS(12) = DJ - LATITUDINAL DIRECTION INCREMENT -C IGDS(13) = SCANNING MODE FLAGS (CODE TABLE 8) -C IGDS(14) = ... THROUGH ... -C IGDS(18) = ... NOT USED FOR THIS GRID -C -C CURVILINEAR ORTHOGONAL GRID -C IGDS( 1) = NUMBER OF VERTICAL COORDINATES -C IGDS( 2) = PV, PL OR 255 -C IGDS( 3) = DATA REPRESENTATION TYPE (CODE TABLE 6) [204] -C IGDS( 4) = NI - NUMBER OF DATA POINTS IN EACH ROW -C IGDS( 5) = NJ - NUMBER OF ROWS -C IGDS( 6) = RESERVED (SET TO 0) -C IGDS( 7) = RESERVED (SET TO 0) -C IGDS( 8) = RESOLUTION AND COMPONENT FLAG (CODE TABLE 7) -C IGDS( 9) = RESERVED (SET TO 0) -C IGDS(10) = RESERVED (SET TO 0) -C IGDS(11) = RESERVED (SET TO 0) -C IGDS(12) = RESERVED (SET TO 0) -C IGDS(13) = SCANNING MODE FLAGS (CODE TABLE 8) -C IGDS(14) = ... THROUGH ... -C IGDS(18) = ... NOT USED FOR THIS GRID -C -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM SP -C -C$$$ -C - INTEGER IGRID - INTEGER IGDS (*) - INTEGER GRD1 (18) - INTEGER GRD2 (18) - INTEGER GRD3 (18) - INTEGER GRD4 (18) - INTEGER GRD5 (18) - INTEGER GRD6 (18) - INTEGER GRD8 (18) - INTEGER GRD10 (18) - INTEGER GRD11 (18) - INTEGER GRD12 (18) - INTEGER GRD13 (18) - INTEGER GRD14 (18) - INTEGER GRD15 (18) - INTEGER GRD16 (18) - INTEGER GRD17 (18) - INTEGER GRD18 (18) - INTEGER GRD21 (55) - INTEGER GRD22 (55) - INTEGER GRD23 (55) - INTEGER GRD24 (55) - INTEGER GRD25 (37) - INTEGER GRD26 (37) - INTEGER GRD27 (18) - INTEGER GRD28 (18) - INTEGER GRD29 (18) - INTEGER GRD30 (18) - INTEGER GRD33 (18) - INTEGER GRD34 (18) - INTEGER GRD37 (91) - INTEGER GRD38 (91) - INTEGER GRD39 (91) - INTEGER GRD40 (91) - INTEGER GRD41 (91) - INTEGER GRD42 (91) - INTEGER GRD43 (91) - INTEGER GRD44 (91) - INTEGER GRD45 (18) - INTEGER GRD53 (18) - INTEGER GRD55 (18) - INTEGER GRD56 (18) - INTEGER GRD61 (64) - INTEGER GRD62 (64) - INTEGER GRD63 (64) - INTEGER GRD64 (64) - INTEGER GRD83 (18) - INTEGER GRD85 (18) - INTEGER GRD86 (18) - INTEGER GRD87 (18) - INTEGER GRD88 (18) - INTEGER GRD90 (18) - INTEGER GRD91 (18) - INTEGER GRD92 (18) - INTEGER GRD93 (18) - INTEGER GRD94 (18) - INTEGER GRD95 (18) - INTEGER GRD96 (18) - INTEGER GRD97 (18) - INTEGER GRD98 (18) - INTEGER GRD99 (18) - INTEGER GRD100(18) - INTEGER GRD101(18) - INTEGER GRD103(18) - INTEGER GRD104(18) - INTEGER GRD105(18) - INTEGER GRD106(18) - INTEGER GRD107(18) - INTEGER GRD110(18) - INTEGER GRD120(18) - INTEGER GRD122(18) - INTEGER GRD123(18) - INTEGER GRD124(18) - INTEGER GRD125(18) - INTEGER GRD126(18) - INTEGER GRD127(18) - INTEGER GRD128(18) - INTEGER GRD129(18) - INTEGER GRD130(18) - INTEGER GRD132(18) - INTEGER GRD138(18) - INTEGER GRD139(18) - INTEGER GRD140(18) - INTEGER GRD145(18) - INTEGER GRD146(18) - INTEGER GRD147(18) - INTEGER GRD148(18) - INTEGER GRD150(18) - INTEGER GRD151(18) - INTEGER GRD160(18) - INTEGER GRD161(18) - INTEGER GRD163(18) - INTEGER GRD170(18) - INTEGER GRD171(18) - INTEGER GRD172(18) - INTEGER GRD173(18) - INTEGER GRD174(18) - INTEGER GRD175(18) - INTEGER GRD176(18) - INTEGER GRD179(18) - INTEGER GRD180(18) - INTEGER GRD181(18) - INTEGER GRD182(18) - INTEGER GRD183(18) - INTEGER GRD184(18) - INTEGER GRD187(18) - INTEGER GRD188(18) - INTEGER GRD189(18) - INTEGER GRD190(18) - INTEGER GRD192(18) - INTEGER GRD193(18) - INTEGER GRD194(18) - INTEGER GRD195(18) - INTEGER GRD196(18) - INTEGER GRD197(18) - INTEGER GRD198(18) - INTEGER GRD199(18) - INTEGER GRD200(18) - INTEGER GRD201(18) - INTEGER GRD202(18) - INTEGER GRD203(18) - INTEGER GRD204(18) - INTEGER GRD205(18) - INTEGER GRD206(18) - INTEGER GRD207(18) - INTEGER GRD208(18) - INTEGER GRD209(18) - INTEGER GRD210(18) - INTEGER GRD211(18) - INTEGER GRD212(18) - INTEGER GRD213(18) - INTEGER GRD214(18) - INTEGER GRD215(18) - INTEGER GRD216(18) - INTEGER GRD217(18) - INTEGER GRD218(18) - INTEGER GRD219(18) - INTEGER GRD220(18) - INTEGER GRD221(18) - INTEGER GRD222(18) - INTEGER GRD223(18) - INTEGER GRD224(18) - INTEGER GRD225(18) - INTEGER GRD226(18) - INTEGER GRD227(18) - INTEGER GRD228(18) - INTEGER GRD229(18) - INTEGER GRD230(18) - INTEGER GRD231(18) - INTEGER GRD232(18) - INTEGER GRD233(18) - INTEGER GRD234(18) - INTEGER GRD235(18) - INTEGER GRD236(18) - INTEGER GRD237(18) - INTEGER GRD238(18) - INTEGER GRD239(18) - INTEGER GRD240(18) - INTEGER GRD241(18) - INTEGER GRD242(18) - INTEGER GRD243(18) - INTEGER GRD244(18) - INTEGER GRD245(18) - INTEGER GRD246(18) - INTEGER GRD247(18) - INTEGER GRD248(18) - INTEGER GRD249(18) - INTEGER GRD250(18) - INTEGER GRD251(18) - INTEGER GRD252(18) - INTEGER GRD253(18) - INTEGER GRD254(18) -C - DATA GRD1 / 0, 255, 1, 73, 23, -48090, 0, 128, 48090, - & 0, 513669,513669, 22500, 64, 0, 0, 0, 0/ - DATA GRD2 / 0, 255, 0, 144, 73, 90000, 0, 128, -90000, - & -2500, 2500, 2500, 0, 0, 0, 0, 0, 0/ - DATA GRD3 / 0, 255, 0, 360,181, 90000, 0, 128, -90000, - & -1000, 1000, 1000, 0, 0, 0, 0, 0, 0/ - DATA GRD4 / 0, 255, 0, 720,361, 90000, 0, 128, -90000, - & -500, 500, 500, 0, 0, 0, 0, 0, 0/ - DATA GRD5 / 0, 255, 5, 53, 57, 7647, -133443, 8, -105000, - & 190500, 190500, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD6 / 0, 255, 5, 53, 45, 7647, -133443, 8, -105000, - & 190500, 190500, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD8 / 0, 255, 1, 116, 44, -48670, 3104, 128, 61050, - & 0, 318830, 318830, 22500, 64, 0, 0, 0, 0/ - DATA GRD10 / 0, 255, 0, 180, 139, 64000, 1000, 128, -74000, - & 359000, 1000, 2000, 0, 0, 0, 0, 0, 0/ - DATA GRD11 / 0, 255, 0, 720, 311, 77500, 0, 128, -77500, - & 359500, 500, 500, 0, 0, 0, 0, 0, 0/ - DATA GRD12 / 0, 255, 0, 301, 331, 55000, 260000, 128, 0, - & 310000, 166, 166, 0, 0, 0, 0, 0, 0/ - DATA GRD13 / 0, 255, 0, 241, 151, 50000, 210000, 128, 25000, - & 250000, 166, 166, 0, 0, 0, 0, 0, 0/ - DATA GRD14 / 0, 255, 0, 511, 301, 30000, 130000, 128, -20000, - & 215000, 166, 166, 0, 0, 0, 0, 0, 0/ - DATA GRD15 / 0, 255, 0, 401, 187, 75000, 140000, 128, 44000, - & 240000, 166, 250, 0, 0, 0, 0, 0, 0/ - DATA GRD16 / 0, 255, 0, 548, 391, 74000, 165000, 128, 48000, - & 237933, 66, 133, 0, 0, 0, 0, 0, 0/ - DATA GRD17 / 0, 255, 0, 736, 526, 50000, 195000, 128, 15000, - & 244000, 66, 66, 0, 0, 0, 0, 0, 0/ - DATA GRD18 / 0, 255, 0, 586, 481, 47000, 261000, 128, 15000, - & 300000, 66, 66, 0, 0, 0, 0, 0, 0/ - DATA GRD21 / 0, 33, 0,65535,37, 0, 0, 128, 90000, - & 180000, 2500, 5000, 64, 0, 0, 0, 0, 0, - & 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, - & 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, - & 37, 37, 37, 37, 37, 37, 1/ - DATA GRD22 / 0, 33, 0,65535,37, 0, -180000, 128, 90000, - & 0, 2500, 5000, 64, 0, 0, 0, 0, 0, - & 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, - & 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, - & 37, 37, 37, 37, 37, 37, 1/ - DATA GRD23 / 0, 33, 0,65535, 37, -90000, 0, 128, 0, - & 180000, 2500, 5000, 64, 0, 0, 0, 0, 0, - & 1, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, - & 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, - & 37, 37, 37, 37, 37, 37, 37/ - DATA GRD24 / 0, 33, 0,65535, 37, -90000, -180000, 128, 0, - & 0, 2500, 5000, 64, 0, 0, 0, 0, 0, - & 1, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, - & 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, 37, - & 37, 37, 37, 37, 37, 37, 37/ - DATA GRD25 / 0, 33, 0,65535, 19, 0, 0, 128, 90000, - & 355000, 5000, 5000, 64, 0, 0, 0, 0, 0, - & 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, - & 72, 72, 72, 1/ - DATA GRD26 / 0, 33, 0,65535, 19, -90000, 0, 128, 0, - & 355000, 5000, 5000, 64, 0, 0, 0, 0, 0, - & 1, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, 72, - & 72, 72, 72, 72/ - DATA GRD27 / 0, 255, 5, 65, 65, -20826, -125000, 8, -80000, - & 381000, 381000, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD28 / 0, 255, 5, 65, 65, 20826, 145000, 8, -80000, - & 381000, 381000,128, 64, 0, 0, 0, 0, 0/ - DATA GRD29 / 0, 255, 0, 145, 37, 0, 0, 128, 90000, - & 360000, 2500, 2500, 64, 0, 0, 0, 0, 0/ - DATA GRD30 / 0, 255, 0, 145, 37, -90000, 0, 128, 0, - & 360000, 2500, 2500, 64, 0, 0, 0, 0, 0/ - DATA GRD33 / 0, 255, 0, 181, 46, 0, 0, 128, 90000, - & 360000, 2000, 2000, 64, 0, 0, 0, 0, 0/ - DATA GRD34 / 0, 255, 0, 181, 46, -90000, 0, 128, 0, - & 360000, 2000, 2000, 64, 0, 0, 0, 0, 0/ - DATA GRD37 / 0, 33, 0,65535,73, 0, -30000, 128, 90000, - & 60000, 1250,65535, 64, 0, 0, 0, 0, 0, - & 73, 73, 73, 73, 73, 73, 73, 73, 72, 72, 72, 71, 71, 71, 70, - & 70, 69, 69, 68, 67, 67, 66, 65, 65, 64, 63, 62, 61, 60, 60, - & 59, 58, 57, 56, 55, 54, 52, 51, 50, 49, 48, 47, 45, 44, 43, - & 42, 40, 39, 38, 36, 35, 33, 32, 30, 29, 28, 26, 25, 23, 22, - & 20, 19, 17, 16, 14, 12, 11, 9, 8, 6, 5, 3, 2/ - DATA GRD38 / 0, 33, 0,65535,73, 0, 60000, 128, 90000, - & 150000, 1250,65535, 64, 0, 0, 0, 0, 0, - & 73, 73, 73, 73, 73, 73, 73, 73, 72, 72, 72, 71, 71, 71, 70, - & 70, 69, 69, 68, 67, 67, 66, 65, 65, 64, 63, 62, 61, 60, 60, - & 59, 58, 57, 56, 55, 54, 52, 51, 50, 49, 48, 47, 45, 44, 43, - & 42, 40, 39, 38, 36, 35, 33, 32, 30, 29, 28, 26, 25, 23, 22, - & 20, 19, 17, 16, 14, 12, 11, 9, 8, 6, 5, 3, 2/ - DATA GRD39 / 0, 33, 0,65535,73, 0, 150000, 128, 90000, - & -120000, 1250,65535, 64, 0, 0, 0, 0, 0, - & 73, 73, 73, 73, 73, 73, 73, 73, 72, 72, 72, 71, 71, 71, 70, - & 70, 69, 69, 68, 67, 67, 66, 65, 65, 64, 63, 62, 61, 60, 60, - & 59, 58, 57, 56, 55, 54, 52, 51, 50, 49, 48, 47, 45, 44, 43, - & 42, 40, 39, 38, 36, 35, 33, 32, 30, 29, 28, 26, 25, 23, 22, - & 20, 19, 17, 16, 14, 12, 11, 9, 8, 6, 5, 3, 2/ - DATA GRD40 / 0, 33, 0,65535,73, 0, -120000, 128, 90000, - & -30000, 1250,65535, 64, 0, 0, 0, 0, 0, - & 73, 73, 73, 73, 73, 73, 73, 73, 72, 72, 72, 71, 71, 71, 70, - & 70, 69, 69, 68, 67, 67, 66, 65, 65, 64, 63, 62, 61, 60, 60, - & 59, 58, 57, 56, 55, 54, 52, 51, 50, 49, 48, 47, 45, 44, 43, - & 42, 40, 39, 38, 36, 35, 33, 32, 30, 29, 28, 26, 25, 23, 22, - & 20, 19, 17, 16, 14, 12, 11, 9, 8, 6, 5, 3, 2/ - DATA GRD41 / 0, 33, 0,65535,73, -90000, -30000, 128, 0, - & 60000, 1250,65535, 64, 0, 0, 0, 0, 0, - & 2, 3, 5, 6, 8, 9, 11, 12, 14, 16, 17, 19, 20, 22, 23, - & 25, 26, 28, 29, 30, 32, 33, 35, 36, 38, 39, 40, 42, 43, 44, - & 45, 47, 48, 49, 50, 51, 52, 54, 55, 56, 57, 58, 59, 60, 60, - & 61, 62, 63, 64, 65, 65, 66, 67, 67, 68, 69, 69, 70, 70, 71, - & 71, 71, 72, 72, 72, 73, 73, 73, 73, 73, 73, 73, 73/ - DATA GRD42 / 0, 33, 0,65535,73, -90000, 60000, 128, 0, - & 150000, 1250,65535, 64, 0, 0, 0, 0, 0, - & 2, 3, 5, 6, 8, 9, 11, 12, 14, 16, 17, 19, 20, 22, 23, - & 25, 26, 28, 29, 30, 32, 33, 35, 36, 38, 39, 40, 42, 43, 44, - & 45, 47, 48, 49, 50, 51, 52, 54, 55, 56, 57, 58, 59, 60, 60, - & 61, 62, 63, 64, 65, 65, 66, 67, 67, 68, 69, 69, 70, 70, 71, - & 71, 71, 72, 72, 72, 73, 73, 73, 73, 73, 73, 73, 73/ - DATA GRD43 / 0, 33, 0,65535,73, -90000, 150000, 128, 0, - & -120000, 1250,65535, 64, 0, 0, 0, 0, 0, - & 2, 3, 5, 6, 8, 9, 11, 12, 14, 16, 17, 19, 20, 22, 23, - & 25, 26, 28, 29, 30, 32, 33, 35, 36, 38, 39, 40, 42, 43, 44, - & 45, 47, 48, 49, 50, 51, 52, 54, 55, 56, 57, 58, 59, 60, 60, - & 61, 62, 63, 64, 65, 65, 66, 67, 67, 68, 69, 69, 70, 70, 71, - & 71, 71, 72, 72, 72, 73, 73, 73, 73, 73, 73, 73, 73/ - DATA GRD44 / 0, 33, 0,65535,73, -90000, -120000, 128, 0, - & -30000, 1250,65535, 64, 0, 0, 0, 0, 0, - & 2, 3, 5, 6, 8, 9, 11, 12, 14, 16, 17, 19, 20, 22, 23, - & 25, 26, 28, 29, 30, 32, 33, 35, 36, 38, 39, 40, 42, 43, 44, - & 45, 47, 48, 49, 50, 51, 52, 54, 55, 56, 57, 58, 59, 60, 60, - & 61, 62, 63, 64, 65, 65, 66, 67, 67, 68, 69, 69, 70, 70, 71, - & 71, 71, 72, 72, 72, 73, 73, 73, 73, 73, 73, 73, 73/ - DATA GRD45 / 0, 255, 0, 288,145, 90000, 0, 128, -90000, - & -1250, 1250, 1250, 0, 0, 0, 0, 0, 0/ - DATA GRD53 / 0, 255, 1, 117, 51, -61050, 0, 128, 61050, - & 0, 318830, 318830, 22500, 64, 0, 0, 0, 0/ - DATA GRD55 / 0, 255, 5, 87, 71, -10947, -154289, 8, -105000, - & 254000, 254000, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD56 / 0, 255, 5, 87, 71, 7647, -133443, 8, -105000, - & 127000, 127000, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD61 / 0, 33, 0,65535, 46, 0, 0, 128, 90000, - & 180000, 2000, 2000, 64, 0, 0, 0, 0, 0, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 1/ - DATA GRD62 / 0, 33, 0,65535, 46, 0, -180000, 128, 90000, - & 0, 2000, 2000, 64, 0, 0, 0, 0, 0, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 1/ - DATA GRD63 / 0, 33, 0,65535, 46, 0, -90000, 128, 0, - & 180000, 2000, 2000, 64, 0, 0, 0, 0, 0, - & 1, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91/ - DATA GRD64 / 0, 33, 0,65535, 46, -90000, -180000, 128, 0, - & 0, 2000, 2000, 64, 0, 0, 0, 0, 0, - & 1, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, 91, - & 91/ - DATA GRD83 / 0, 255,205,758,567, 2228, -140481, 136, 47500, - & -104000, 121,121,64, 53492, -10984, 0, 0, 0/ - DATA GRD85 / 0, 255, 0, 360, 90, 500, 500, 128, 89500, - & 359500, 1000, 1000, 64, 0, 0, 0, 0, 0/ - DATA GRD86 / 0, 255, 0, 360, 90, -89500, 500, 128, -500, - & 359500, 1000, 1000, 64, 0, 0, 0, 0, 0/ - DATA GRD87 / 0, 255, 5, 81, 62, 22876, -120491, 8, -105000, - & 68153, 68153, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD88 / 0, 255, 5, 580,548, 10000, -128000, 8, -105000, - & 15000, 15000, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD90 / 0, 255, 3,4289,2753, 20192, -121554, 8, -95000, - & 1270, 1270, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD91 / 0, 255, 5,1649,1105, 40530, -178571, 8, -150000, - & 2976, 2976, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD92 / 0, 255, 5,3297,2209, 40530, -178571, 8, -150000, - & 1488, 1488, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD93 / 0, 255,203,223,501, 44232, -169996, 136, 63000, - & -150000, 67,66,64, 0, 0, 0, 0, 0/ - DATA GRD94 / 0, 255,205,595,625, 34921, -161663, 136, 54000, - & -106000, 63, 54,64, 83771, -151721, 0, 0, 0/ - DATA GRD95 / 0, 255,205,401,325, 17609, -76327, 136, 54000, - & -106000, 31, 27,64, 18840, -61261, 0, 0, 0/ - DATA GRD96 / 0, 255,205,373,561, 11625, -156339, 136, 54000, - & -106000, 31, 27,64, 30429, -157827, 0, 0, 0/ - DATA GRD97 / 0, 255,205,1371,1100, 15947,-125468, 136, 54000, - & -106000, 42, 36,64,45407,-52390, 0, 0, 0/ - DATA GRD98 / 0, 255, 4, 192, 94, 88542, 0, 128, -88542, - & -1875, 47,1875, 0, 0, 0, 0, 0, 0/ - DATA GRD99 / 0, 255,203,669,1165, -7450, -144140, 136, 54000, - & -106000, 90, 77, 64, 0, 0, 0, 0, 0/ - DATA GRD100/ 0, 255, 5, 83, 83, 17108, -129296, 8, -105000, - & 91452, 91452, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD101/ 0, 255, 5, 113, 91, 10528, -137146, 8, -105000, - & 91452, 91452, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD103/ 0, 255, 5, 65, 56, 22405, -121352, 8, -105000, - & 91452, 91452, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD104/ 0, 255, 5, 147,110, -268, -139475, 8, -105000, - & 90755, 90755, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD105/ 0, 255, 5, 83, 83, 17529, -129296, 8, -105000, - & 90755, 90755, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD106/ 0, 255, 5, 165,117, 17533, -129296, 8, -105000, - & 45373, 45373, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD107/ 0, 255, 5, 120, 92, 23438, -120168, 8, -105000, - & 45373, 45373, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD110/ 0, 255, 0, 464,224, 25063, -124938, 128, 52938, - & -67063, 125, 125, 64, 0, 0, 0, 0, 0/ - DATA GRD120/ 0, 255,204,1200,1684, 0, 0, 8, 0, - & 0, 0, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD122/ 0, 255,204, 350, 465, 0, 0, 8, 0, - & 0, 0, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD123/ 0, 255,204, 280, 360, 0, 0, 8, 0, - & 0, 0, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD124/ 0, 255,204, 240, 314, 0, 0, 8, 0, - & 0, 0, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD125/ 0, 255,204, 300, 340, 0, 0, 8, 0, - & 0, 0, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD126/ 0, 255, 4, 384,190, 89277, 0, 128, -89277, - & -938, 95, 938, 0, 0, 0, 0, 0, 0/ - DATA GRD127/ 0, 255, 4, 768,384, 89642, 0, 128, -89642, - & -469, 192, 469, 0, 0, 0, 0, 0, 0/ - DATA GRD128/ 0, 255, 4,1152,576, 89761, 0, 128, -89761, - & -313, 288, 313, 0, 0, 0, 0, 0, 0/ - DATA GRD129/ 0, 255, 4,1760,880, 89844, 0, 128, -89844, - & -205, 440, 205, 0, 0, 0, 0, 0, 0/ - DATA GRD130/ 0, 255, 3, 451,337, 16281, -126138, 8, -95000, - & 13545, 13545, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD132/ 0, 255, 3, 697,553, 1000, -145500, 8, -107000, - & 16232, 16232, 0, 64, 0, 50000, 50000, 0, 0/ - DATA GRD138/ 0, 255, 3, 468,288, 21017, -123282, 8, -97000, - & 12000, 12000, 0, 64, 0, 33000, 45000, 0, 0/ - DATA GRD139/ 0, 255, 3, 80,52, 17721, -161973, 8, -157500, - & 12000, 12000, 0, 64, 0, 19000, 21000, 0, 0/ - DATA GRD140/ 0, 255, 3, 199,163, 53020, -166477, 8, -148600, - & 12000, 12000, 0, 64, 0, 57000, 63000, 0, 0/ - DATA GRD145/ 0, 255, 3, 169,145, 32174, -90159, 8, -79500, - & 12000, 12000, 0, 64, 0, 36000, 46000, 0, 0/ - DATA GRD146/ 0, 255, 3, 166,142, 32353, -89994, 8, -79500, - & 12000, 12000, 0, 64, 0, 36000, 46000, 0, 0/ - DATA GRD147/ 0, 255, 3, 268,259, 24595, -100998, 8, -97000, - & 12000, 12000, 0, 64, 0, 33000, 45000, 0, 0/ - DATA GRD148/ 0, 255, 3, 442,265, 21821, -120628, 8, -97000, - & 12000, 12000, 0, 64, 0, 33000, 45000, 0, 0/ - DATA GRD150/ 0, 255, 0, 401,201, 5000, -100000, 128, 25000, - & -60000, 100, 100, 64, 0, 0, 0, 0, 0/ - DATA GRD151/ 0, 255, 5, 478, 429, -7450, 215860, 8, -110000, - & 33812, 33812, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD160/ 0, 255, 5, 180,156, 19132, -185837, 8, -150000, - & 47625, 47625, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD161/ 0, 255, 0, 137,102, 50750, 271750, 72, -250, - & -19750, 500,500, 0, 0, 0, 0, 0, 0/ - DATA GRD163/ 0, 255, 3,1008,722, 20600, -118300, 8, -95000, - & 5000, 5000, 0, 64, 0, 38000, 38000, 0, 0/ - DATA GRD170/ 0, 255, 4, 512, 256, 89463, 0, 128, -89463, - & -703, 128, 703, 0, 0, 0, 0, 0, 0/ - DATA GRD171/ 0, 255, 5, 770,930, 25032, -119560, 0, -80000, - & 12700, 12700, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD172/ 0, 255, 5, 690,710, -36866, -220194, 0, -260000, - & 12700, 12700, 128, 64, 0, 0, 0, 0, 0/ - DATA GRD173/ 0, 255, 0,4320,2160, 89958, 42, 128, -89958, - & 359958, 83, 83, 0, 0, 0, 0, 0, 0/ - DATA GRD174/ 0, 255, 0,2880,1440, 89938, 62, 128, -89938, - & -62, 125, 125,64, 0, 0, 0, 0, 0/ - DATA GRD175/ 0, 255, 0, 556,334, 0, 130000, 128, 30060, - & 180040, 90, 90, 64, 0, 0, 0, 0, 0/ - DATA GRD176/ 0, 255, 0, 327,235, 49100, -92200, 128, 40910, - & -75900, 35, 50, 0, 0, 0, 0, 0, 0/ - DATA GRD179/ 0, 255, 5,1196,817, -2500, -142500, 8, -100000, - & 12679, 12679, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD180/ 0, 255, 0, 759,352, 55054, -127000, 128, 17146, - & -45136, 108, 108, 0, 0, 0, 0, 0, 0/ - DATA GRD181/ 0, 255, 0, 370,278, 30054, -100000, 128, 138, - & -60148, 108, 108, 0, 0, 0, 0, 0, 0/ - DATA GRD182/ 0, 255, 0, 278,231, 32973, -170000, 128, 8133, - & -140084, 108, 108, 0, 0, 0, 0, 0, 0/ - DATA GRD183/ 0, 255, 0, 648,278, 75054, -200000, 128, 45138, - & -130124, 108, 108, 0, 0, 0, 0, 0, 0/ - DATA GRD184/ 0, 255, 3,2145,1377, 20192, -121554, 8, -95000, - & 2540, 2540, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD187/ 0, 255, 3,2145,1597, 20192, -121554, 8, -95000, - & 2540, 2540, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD188/ 0, 255, 3, 709, 795, 37979, -125958, 8, -95000, - & 2540, 2540, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD189/ 0, 255, 5, 655, 855, 51500, -142500, 8, -135000, - & 1448, 1448, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD190/ 0, 255,205,954,835, -7491, -144134, 136, 54000, - & -106000, 126, 108, 64, 44540, 14802, 0, 0, 0/ - DATA GRD192/ 0, 255,203,237,387, -3441, -148799, 136, 50000, - & -111000, 225,207,64, 0, 0, 0, 0, 0/ - DATA GRD193 / 0, 255, 0, 1440, 721, 90000, 0, 128, -90000, - & -250, 250, 250, 0, 0, 0, 0, 0, 0/ - DATA GRD194/ 0, 255, 1, 544,310, 15000, -75500, 128, 22005, - & -62509, 2500, 2500, 20000, 64, 0, 0, 0, 0/ - DATA GRD195/ 0, 255, 1, 177,129, 16829, -68196, 128, 19747, - & -63972, 2500, 2500, 20000, 64, 0, 0, 0, 0/ - DATA GRD196/ 0, 255, 1, 321,225, 18073, -161525, 136, 23088, - & -153869, 2500, 2500, 20000, 64, 0, 0, 0, 0/ - DATA GRD197/ 0, 255, 3,1073,689, 20192, -121550, 8, -95000, - & 5079, 5079, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD198/ 0, 255, 5, 825, 553, 40530, -178571, 8, -150000, - & 5953, 5953, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD199/ 0, 255, 1, 193,193, 12350, -216313, 128, 16794, - & -211720, 2500, 2500, 20000, 64, 0, 0, 0, 0/ - DATA GRD200/ 0, 255, 3, 108, 94, 16201, 285720, 8, -107000, - & 16232, 16232, 0, 64, 0, 50000, 50000, 0, 0/ - DATA GRD201/ 0, 255, 5, 65, 65, -20826, -150000, 8, -105000, - & 381000, 381000, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD202/ 0, 255, 5, 65, 43, 7838, -141028, 8, -105000, - & 190500, 190500, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD203/ 0, 255, 5, 45, 39, 19132, -185837, 8, -150000, - & 190500, 190500, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD204/ 0, 255, 1, 93, 68, -25000, 110000, 128, 60644, - & -109129, 160000, 160000, 20000, 64, 0, 0, 0, 0/ - DATA GRD205/ 0, 255, 5, 45, 39, 616, -84904, 8, -60000, - & 190500, 190500, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD206/ 0, 255, 3, 51, 41, 22289, -117991, 8, - 95000, - & 81271, 81271, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD207/ 0, 255, 5, 49, 35, 42085, -175641, 8, -150000, - & 95250, 95250, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD208/ 0, 255, 1, 29, 27, 9343, -167315, 128, 28092, - & -145878, 80000, 80000, 20000, 64, 0, 0, 0, 0/ - DATA GRD209/ 0, 255, 3, 275,223, -4850, -151100, 8, -111000, - & 44000, 44000, 0, 64, 0, 45000, 45000, 0, 0/ - DATA GRD210/ 0, 255, 1, 25, 25, 9000, -77000, 128, 26422, - & -58625, 80000, 80000, 20000, 64, 0, 0, 0, 0/ - DATA GRD211/ 0, 255, 3, 93, 65, 12190, -133459, 8, -95000, - & 81271, 81271, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD212/ 0, 255, 3, 185,129, 12190, -133459, 8, -95000, - & 40635, 40635, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD213/ 0, 255, 5, 129, 85, 7838, -141028, 8, -105000, - & 95250, 95250, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD214/ 0, 255, 5, 97, 69, 42085, -175641, 8, -150000, - & 47625, 47625, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD215/ 0, 255, 3, 369,257, 12190, -133459, 8, -95000, - & 20318, 20318, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD216/ 0, 255, 5, 139,107, 30000, -173000, 8, -135000, - & 45000, 45000, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD217/ 0, 255, 5, 277,213, 30000, -173000, 8, -135000, - & 22500, 22500, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD218/ 0, 255, 3, 614,428, 12190, -133459, 8, -95000, - & 12191, 12191, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD219/ 0, 255, 5, 385,465, 25032, -119560, 0, -80000, - & 25400, 25400, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD220/ 0, 255, 5, 345,355, -36866, -220194, 0, -260000, - & 25400, 25400, 128, 64, 0, 0, 0, 0, 0/ - DATA GRD221/ 0, 255, 3, 349,277, 1000, -145500, 8, -107000, - & 32463, 32463, 0, 64, 0, 50000, 50000, 0, 0/ - DATA GRD222/ 0, 255, 3, 138,112, -4850, -151100, 8, -111000, - & 88000, 88000, 0, 64, 0, 45000, 45000, 0, 0/ - DATA GRD223/ 0, 255, 5, 129,129, -20826, -150000, 8, -105000, - & 190500, 190500, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD224/ 0, 255, 5, 65, 65, 20826, 120000, 8, -105000, - & 381000, 381000, 128, 64, 0, 0, 0, 0, 0/ - DATA GRD225/ 0, 255, 1, 185,135, -25000, -250000, 128, 60640, - & -109129, 80000, 80000, 20000, 64, 0, 0, 0, 0/ - DATA GRD226/ 0, 255, 3, 737,513, 12190, -133459, 8, -95000, - & 10159, 10159, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD227/ 0, 255, 3,1473,1025, 12190, -133459, 8, -95000, - & 5079, 5079, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD228/ 0, 255, 0, 144, 73, 90000, 0, 128, -90000, - & -2500, 2500, 2500, 64, 0, 0, 0, 0, 0/ - DATA GRD229/ 0, 255, 0, 360,181, 90000, 0, 128, -90000, - & -1000, 1000, 1000, 64, 0, 0, 0, 0, 0/ - DATA GRD230/ 0, 255, 0, 720,361, 90000, 0, 128, -90000, - & -500, 500, 500, 64, 0, 0, 0, 0, 0/ - DATA GRD231/ 0, 255, 0, 720,181, 0, 0, 128, 90000, - & -500, 500, 500, 64, 0, 0, 0, 0, 0/ - DATA GRD232/ 0, 255, 0, 360, 91, 0, 0, 128, 90000, - & -1000, 1000, 1000, 64, 0, 0, 0, 0, 0/ - DATA GRD233/ 0, 255, 0, 288,157, 78000, 0, 128, -78000, - & -1250, 1000, 1250, 0, 0, 0, 0, 0, 0/ - DATA GRD234/ 0, 255, 0, 133,121, 15000, -98000, 128, -45000, - & -65000, 250, 250, 64, 0, 0, 0, 0, 0/ - DATA GRD235/ 0, 255, 0, 720,360, 89750, 250, 128, -89750, - & -250, 500, 500, 0, 0, 0, 0, 0, 0/ - DATA GRD236/ 0, 255, 3, 151,113, 16281, 233862, 8, -95000, - & 40635, 40635, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD237/ 0, 255, 3, 54, 47, 16201, 285720, 8, -107000, - & 32463, 32463, 0, 64, 0, 50000, 50000, 0, 0/ - DATA GRD238/ 0, 255, 0, 275, 203, 50250, 261750, 128, -250, - & -29750, 250, 250, 0, 0, 0, 0, 0, 0/ - DATA GRD239/ 0, 255, 0, 155, 123, 75250, 159500, 128, 44750, - & -123500, 250, 500, 0, 0, 0, 0, 0, 0/ - DATA GRD240/ 0, 255, 5, 1121, 881, 23098, -119036, 8, -105000, - & 4763, 4763, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD241/ 0, 255, 3, 549,445, -4850, -151100, 8, -111000, - & 22000, 22000, 0, 64, 0, 45000, 45000, 0, 0/ - DATA GRD242/ 0, 255, 5, 553,425, 30000, -173000, 8, -135000, - & 11250, 11250, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD243/ 0, 255, 0, 126,101, 10000, -170000, 128, 50000, - & -120000, 400, 400, 64, 0, 0, 0, 0, 0/ - DATA GRD244/ 0, 255, 0, 275, 203, 50250, 261750, 128, -250, - & -29750, 250, 250, 0, 0, 0, 0, 0, 0/ - DATA GRD245/ 0, 255, 3, 336,372, 22980, -92840, 8, -80000, - & 8000, 8000, 0, 64, 0, 35000, 35000, 0, 0/ - DATA GRD246/ 0, 255, 3, 332,371, 25970, -127973, 8, -115000, - & 8000, 8000, 0, 64, 0, 40000, 40000, 0, 0/ - DATA GRD247/ 0, 255, 3, 336,372, 22980, -110840, 8, -98000, - & 8000, 8000, 0, 64, 0, 35000, 35000, 0, 0/ - DATA GRD248/ 0, 255, 0, 135,101, 14500, -71500, 128, 22000, - & -61450, 75, 75, 64, 0, 0, 0, 0, 0/ - DATA GRD249/ 0, 255, 5, 367,343, 45400, -171600, 8, -150000, - & 9868, 9868, 0, 64, 0, 0, 0, 0, 0/ - DATA GRD250/ 0, 255, 0, 135,101, 16500, -162000, 128, 24000, - & -151950, 75, 75, 64, 0, 0, 0, 0, 0/ - DATA GRD251/ 0, 255, 0, 332,210, 26350, -83050, 128, 47250, - & -49950, 100, 100, 64, 0, 0, 0, 0, 0/ - DATA GRD252/ 0, 255, 3, 301,225, 16281, 233862, 8, 265000, - & 20318, 20318, 0, 64, 0, 25000, 25000, 0, 0/ - DATA GRD253/ 0, 255, 0, 373,224, 60500, 189750, 128, 4750, - & -77250, 250, 250, 0, 0, 0, 0, 0, 0/ - DATA GRD254/ 0, 255, 1, 369,300, -35000, -250000, 128, 60789, - & -109129, 40000,40000, 20000, 64, 0, 0, 0, 0/ -C - IERR = 0 -C - DO 1 I = 1,18 - IGDS(I) = 0 - 1 CONTINUE -C - IF (IGRID.GE.37.AND.IGRID.LE.44) THEN - DO 2 I = 19,91 - IGDS(I) = 0 - 2 CONTINUE - END IF -C - IF (IGRID.GE.21.AND.IGRID.LE.24) THEN - DO I = 19,55 - IGDS(I) = 0 - END DO - END IF -C - IF (IGRID.GE.25.AND.IGRID.LE.26) THEN - DO I = 19,37 - IGDS(I) = 0 - END DO - END IF -C - IF (IGRID.GE.61.AND.IGRID.LE.64) THEN - DO I = 19,64 - IGDS(I) = 0 - END DO - END IF -C - IF (IGRID.EQ.1) THEN - DO 3 I = 1,18 - IGDS(I) = GRD1(I) - 3 CONTINUE -C - ELSE IF (IGRID.EQ.2) THEN - DO 4 I = 1,18 - IGDS(I) = GRD2(I) - 4 CONTINUE -C - ELSE IF (IGRID.EQ.3) THEN - DO 5 I = 1,18 - IGDS(I) = GRD3(I) - 5 CONTINUE -C - ELSE IF (IGRID.EQ.4) THEN - DO 6 I = 1,18 - IGDS(I) = GRD4(I) - 6 CONTINUE -C - ELSE IF (IGRID.EQ.5) THEN - DO 10 I = 1,18 - IGDS(I) = GRD5(I) - 10 CONTINUE -C - ELSE IF (IGRID.EQ.6) THEN - DO 20 I = 1,18 - IGDS(I) = GRD6(I) - 20 CONTINUE -C - ELSE IF (IGRID.EQ.8) THEN - DO I = 1,18 - IGDS(I) = GRD8(I) - END DO -C - ELSE IF (IGRID.EQ.10) THEN - DO I = 1,18 - IGDS(I) = GRD10(I) - END DO -C - ELSE IF (IGRID.EQ.11) THEN - DO I = 1,18 - IGDS(I) = GRD11(I) - END DO -C - ELSE IF (IGRID.EQ.12) THEN - DO I = 1,18 - IGDS(I) = GRD12(I) - END DO -C - ELSE IF (IGRID.EQ.13) THEN - DO I = 1,18 - IGDS(I) = GRD13(I) - END DO -C - ELSE IF (IGRID.EQ.14) THEN - DO I = 1,18 - IGDS(I) = GRD14(I) - END DO -C - ELSE IF (IGRID.EQ.15) THEN - DO I = 1,18 - IGDS(I) = GRD15(I) - END DO -C - ELSE IF (IGRID.EQ.16) THEN - DO I = 1,18 - IGDS(I) = GRD16(I) - END DO -C - ELSE IF (IGRID.EQ.17) THEN - DO I = 1,18 - IGDS(I) = GRD17(I) - END DO -C - ELSE IF (IGRID.EQ.18) THEN - DO I = 1,18 - IGDS(I) = GRD18(I) - END DO -C - ELSE IF (IGRID.EQ.21) THEN - DO 30 I = 1,55 - IGDS(I) = GRD21(I) - 30 CONTINUE -C - ELSE IF (IGRID.EQ.22) THEN - DO 40 I = 1,55 - IGDS(I) = GRD22(I) - 40 CONTINUE -C - ELSE IF (IGRID.EQ.23) THEN - DO 50 I = 1,55 - IGDS(I) = GRD23(I) - 50 CONTINUE -C - ELSE IF (IGRID.EQ.24) THEN - DO 60 I = 1,55 - IGDS(I) = GRD24(I) - 60 CONTINUE -C - ELSE IF (IGRID.EQ.25) THEN - DO 70 I = 1,37 - IGDS(I) = GRD25(I) - 70 CONTINUE -C - ELSE IF (IGRID.EQ.26) THEN - DO 80 I = 1,37 - IGDS(I) = GRD26(I) - 80 CONTINUE -C - ELSE IF (IGRID.EQ.27) THEN - DO 90 I = 1,18 - IGDS(I) = GRD27(I) - 90 CONTINUE -C - ELSE IF (IGRID.EQ.28) THEN - DO 100 I = 1,18 - IGDS(I) = GRD28(I) - 100 CONTINUE -C - ELSE IF (IGRID.EQ.29) THEN - DO 110 I = 1,18 - IGDS(I) = GRD29(I) - 110 CONTINUE -C - ELSE IF (IGRID.EQ.30) THEN - DO 120 I = 1,18 - IGDS(I) = GRD30(I) - 120 CONTINUE -C - ELSE IF (IGRID.EQ.33) THEN - DO 130 I = 1,18 - IGDS(I) = GRD33(I) - 130 CONTINUE -C - ELSE IF (IGRID.EQ.34) THEN - DO 140 I = 1,18 - IGDS(I) = GRD34(I) - 140 CONTINUE -C - ELSE IF (IGRID.EQ.37) THEN - DO 141 I = 1,91 - IGDS(I) = GRD37(I) - 141 CONTINUE -C - ELSE IF (IGRID.EQ.38) THEN - DO 142 I = 1,91 - IGDS(I) = GRD38(I) - 142 CONTINUE -C - ELSE IF (IGRID.EQ.39) THEN - DO 143 I = 1,91 - IGDS(I) = GRD39(I) - 143 CONTINUE -C - ELSE IF (IGRID.EQ.40) THEN - DO 144 I = 1,91 - IGDS(I) = GRD40(I) - 144 CONTINUE -C - ELSE IF (IGRID.EQ.41) THEN - DO 145 I = 1,91 - IGDS(I) = GRD41(I) - 145 CONTINUE -C - ELSE IF (IGRID.EQ.42) THEN - DO 146 I = 1,91 - IGDS(I) = GRD42(I) - 146 CONTINUE -C - ELSE IF (IGRID.EQ.43) THEN - DO 147 I = 1,91 - IGDS(I) = GRD43(I) - 147 CONTINUE -C - ELSE IF (IGRID.EQ.44) THEN - DO 148 I = 1,91 - IGDS(I) = GRD44(I) - 148 CONTINUE -C - ELSE IF (IGRID.EQ.45) THEN - DO 149 I = 1,18 - IGDS(I) = GRD45(I) - 149 CONTINUE -C - ELSE IF (IGRID.EQ.53) THEN - DO I = 1,18 - IGDS(I) = GRD53(I) - END DO -C - ELSE IF (IGRID.EQ.55) THEN - DO 152 I = 1,18 - IGDS(I) = GRD55(I) - 152 CONTINUE -C - ELSE IF (IGRID.EQ.56) THEN - DO 154 I = 1,18 - IGDS(I) = GRD56(I) - 154 CONTINUE -C - ELSE IF (IGRID.EQ.61) THEN - DO 160 I = 1,64 - IGDS(I) = GRD61(I) - 160 CONTINUE -C - ELSE IF (IGRID.EQ.62) THEN - DO 170 I = 1,64 - IGDS(I) = GRD62(I) - 170 CONTINUE -C - ELSE IF (IGRID.EQ.63) THEN - DO 180 I = 1,64 - IGDS(I) = GRD63(I) - 180 CONTINUE -C - ELSE IF (IGRID.EQ.64) THEN - DO 190 I = 1,64 - IGDS(I) = GRD64(I) - 190 CONTINUE -C - ELSE IF (IGRID.EQ.83) THEN - DO I = 1,18 - IGDS(I) = GRD83(I) - ENDDO -C - ELSE IF (IGRID.EQ.85) THEN - DO 192 I = 1,18 - IGDS(I) = GRD85(I) - 192 CONTINUE -C - ELSE IF (IGRID.EQ.86) THEN - DO 194 I = 1,18 - IGDS(I) = GRD86(I) - 194 CONTINUE -C - ELSE IF (IGRID.EQ.87) THEN - DO 195 I = 1,18 - IGDS(I) = GRD87(I) - 195 CONTINUE -C - ELSE IF (IGRID.EQ.88) THEN - DO 2195 I = 1,18 - IGDS(I) = GRD88(I) -2195 CONTINUE -C - ELSE IF (IGRID.EQ.90) THEN - DO 196 I = 1,18 - IGDS(I) = GRD90(I) - 196 CONTINUE -C - ELSE IF (IGRID.EQ.91) THEN - DO 197 I = 1,18 - IGDS(I) = GRD91(I) - 197 CONTINUE -C - ELSE IF (IGRID.EQ.92) THEN - DO 198 I = 1,18 - IGDS(I) = GRD92(I) - 198 CONTINUE -C - ELSE IF (IGRID.EQ.93) THEN - DO 199 I = 1,18 - IGDS(I) = GRD93(I) - 199 CONTINUE -C - ELSE IF (IGRID.EQ.94) THEN - DO 200 I = 1,18 - IGDS(I) = GRD94(I) - 200 CONTINUE -C - ELSE IF (IGRID.EQ.95) THEN - DO 201 I = 1,18 - IGDS(I) = GRD95(I) - 201 CONTINUE -C - ELSE IF (IGRID.EQ.96) THEN - DO 202 I = 1,18 - IGDS(I) = GRD96(I) - 202 CONTINUE -C - ELSE IF (IGRID.EQ.97) THEN - DO 203 I = 1,18 - IGDS(I) = GRD97(I) - 203 CONTINUE -C - ELSE IF (IGRID.EQ.98) THEN - DO 204 I = 1,18 - IGDS(I) = GRD98(I) - 204 CONTINUE -C - ELSE IF (IGRID.EQ.99) THEN - DO I = 1,18 - IGDS(I) = GRD99(I) - ENDDO -C - ELSE IF (IGRID.EQ.100) THEN - DO 205 I = 1,18 - IGDS(I) = GRD100(I) - 205 CONTINUE -C - ELSE IF (IGRID.EQ.101) THEN - DO 210 I = 1,18 - IGDS(I) = GRD101(I) - 210 CONTINUE -C - ELSE IF (IGRID.EQ.103) THEN - DO 220 I = 1,18 - IGDS(I) = GRD103(I) - 220 CONTINUE -C - ELSE IF (IGRID.EQ.104) THEN - DO 230 I = 1,18 - IGDS(I) = GRD104(I) - 230 CONTINUE -C - ELSE IF (IGRID.EQ.105) THEN - DO 240 I = 1,18 - IGDS(I) = GRD105(I) - 240 CONTINUE -C - ELSE IF (IGRID.EQ.106) THEN - DO 242 I = 1,18 - IGDS(I) = GRD106(I) - 242 CONTINUE -C - ELSE IF (IGRID.EQ.107) THEN - DO 244 I = 1,18 - IGDS(I) = GRD107(I) - 244 CONTINUE -C - ELSE IF (IGRID.EQ.110) THEN - DO I = 1,18 - IGDS(I) = GRD110(I) - ENDDO -C - ELSE IF (IGRID.EQ.120) THEN - DO I = 1,18 - IGDS(I) = GRD120(I) - ENDDO -C - ELSE IF (IGRID.EQ.122) THEN - DO I = 1,18 - IGDS(I) = GRD122(I) - ENDDO -C - ELSE IF (IGRID.EQ.123) THEN - DO I = 1,18 - IGDS(I) = GRD123(I) - ENDDO -C - ELSE IF (IGRID.EQ.124) THEN - DO I = 1,18 - IGDS(I) = GRD124(I) - ENDDO -C - ELSE IF (IGRID.EQ.125) THEN - DO I = 1,18 - IGDS(I) = GRD125(I) - ENDDO -C - ELSE IF (IGRID.EQ.126) THEN - DO 245 I = 1,18 - IGDS(I) = GRD126(I) - 245 CONTINUE -C - ELSE IF (IGRID.EQ.127) THEN - DO I = 1,18 - IGDS(I) = GRD127(I) - ENDDO -C - ELSE IF (IGRID.EQ.128) THEN - DO I = 1,18 - IGDS(I) = GRD128(I) - ENDDO -C - ELSE IF (IGRID.EQ.129) THEN - DO I = 1,18 - IGDS(I) = GRD129(I) - ENDDO -C - ELSE IF (IGRID.EQ.130) THEN - DO I = 1,18 - IGDS(I) = GRD130(I) - ENDDO -C - ELSE IF (IGRID.EQ.132) THEN - DO I = 1,18 - IGDS(I) = GRD132(I) - ENDDO -C - ELSE IF (IGRID.EQ.138) THEN - DO I = 1,18 - IGDS(I) = GRD138(I) - ENDDO -C - ELSE IF (IGRID.EQ.139) THEN - DO I = 1,18 - IGDS(I) = GRD139(I) - ENDDO -C - ELSE IF (IGRID.EQ.140) THEN - DO I = 1,18 - IGDS(I) = GRD140(I) - ENDDO -C - ELSE IF (IGRID.EQ.145) THEN - DO I = 1,18 - IGDS(I) = GRD145(I) - ENDDO -C - ELSE IF (IGRID.EQ.146) THEN - DO I = 1,18 - IGDS(I) = GRD146(I) - ENDDO -C - ELSE IF (IGRID.EQ.147) THEN - DO I = 1,18 - IGDS(I) = GRD147(I) - ENDDO -C - ELSE IF (IGRID.EQ.148) THEN - DO I = 1,18 - IGDS(I) = GRD148(I) - ENDDO -C - ELSE IF (IGRID.EQ.150) THEN - DO I = 1,18 - IGDS(I) = GRD150(I) - ENDDO -C - ELSE IF (IGRID.EQ.151) THEN - DO I = 1,18 - IGDS(I) = GRD151(I) - ENDDO -C - ELSE IF (IGRID.EQ.160) THEN - DO I = 1,18 - IGDS(I) = GRD160(I) - ENDDO -C - ELSE IF (IGRID.EQ.161) THEN - DO I = 1,18 - IGDS(I) = GRD161(I) - ENDDO - ELSE IF (IGRID.EQ.163) THEN - DO I = 1,18 - IGDS(I) = GRD163(I) - ENDDO -C - ELSE IF (IGRID.EQ.170) THEN - DO I = 1,18 - IGDS(I) = GRD170(I) - ENDDO -C - ELSE IF (IGRID.EQ.171) THEN - DO I = 1,18 - IGDS(I) = GRD171(I) - ENDDO -C - ELSE IF (IGRID.EQ.172) THEN - DO I = 1,18 - IGDS(I) = GRD172(I) - ENDDO -C - ELSE IF (IGRID.EQ.173) THEN - DO I = 1,18 - IGDS(I) = GRD173(I) - ENDDO -C - ELSE IF (IGRID.EQ.174) THEN - DO I = 1,18 - IGDS(I) = GRD174(I) - ENDDO -C - ELSE IF (IGRID.EQ.175) THEN - DO I = 1,18 - IGDS(I) = GRD175(I) - ENDDO -C - ELSE IF (IGRID.EQ.176) THEN - DO I = 1,18 - IGDS(I) = GRD176(I) - ENDDO -C - ELSE IF (IGRID.EQ.179) THEN - DO I = 1,18 - IGDS(I) = GRD179(I) - ENDDO -C - ELSE IF (IGRID.EQ.180) THEN - DO I = 1,18 - IGDS(I) = GRD180(I) - ENDDO -C - ELSE IF (IGRID.EQ.181) THEN - DO I = 1,18 - IGDS(I) = GRD181(I) - ENDDO -C - ELSE IF (IGRID.EQ.182) THEN - DO I = 1,18 - IGDS(I) = GRD182(I) - ENDDO -C - ELSE IF (IGRID.EQ.183) THEN - DO I = 1,18 - IGDS(I) = GRD183(I) - ENDDO -C - ELSE IF (IGRID.EQ.184) THEN - DO I = 1,18 - IGDS(I) = GRD184(I) - ENDDO -C - ELSE IF (IGRID.EQ.187) THEN - DO I = 1,18 - IGDS(I) = GRD187(I) - ENDDO -C - ELSE IF (IGRID.EQ.188) THEN - DO I = 1,18 - IGDS(I) = GRD188(I) - ENDDO -C - ELSE IF (IGRID.EQ.189) THEN - DO I = 1,18 - IGDS(I) = GRD189(I) - ENDDO -C - ELSE IF (IGRID.EQ.190) THEN - DO 2190 I = 1,18 - IGDS(I) = GRD190(I) - 2190 CONTINUE -C - ELSE IF (IGRID.EQ.192) THEN - DO 2191 I = 1,18 - IGDS(I) = GRD192(I) - 2191 CONTINUE -C - ELSE IF (IGRID.EQ.193) THEN - DO I = 1,18 - IGDS(I) = GRD193(I) - END DO -C - ELSE IF (IGRID.EQ.194) THEN - DO 2192 I = 1,18 - IGDS(I) = GRD194(I) - 2192 CONTINUE -C - ELSE IF (IGRID.EQ.195) THEN - DO I = 1,18 - IGDS(I) = GRD195(I) - END DO -C - ELSE IF (IGRID.EQ.196) THEN - DO 249 I = 1,18 - IGDS(I) = GRD196(I) - 249 CONTINUE -C - ELSE IF (IGRID.EQ.197) THEN - DO I = 1,18 - IGDS(I) = GRD197(I) - END DO -C - ELSE IF (IGRID.EQ.198) THEN - DO 2490 I = 1,18 - IGDS(I) = GRD198(I) - 2490 CONTINUE -C - ELSE IF (IGRID.EQ.199) THEN - DO I = 1,18 - IGDS(I) = GRD199(I) - END DO -C - ELSE IF (IGRID.EQ.200) THEN - DO I = 1,18 - IGDS(I) = GRD200(I) - END DO -C - ELSE IF (IGRID.EQ.201) THEN - DO 250 I = 1,18 - IGDS(I) = GRD201(I) - 250 CONTINUE -C - ELSE IF (IGRID.EQ.202) THEN - DO 260 I = 1,18 - IGDS(I) = GRD202(I) - 260 CONTINUE -C - ELSE IF (IGRID.EQ.203) THEN - DO 270 I = 1,18 - IGDS(I) = GRD203(I) - 270 CONTINUE -C - ELSE IF (IGRID.EQ.204) THEN - DO 280 I = 1,18 - IGDS(I) = GRD204(I) - 280 CONTINUE -C - ELSE IF (IGRID.EQ.205) THEN - DO 290 I = 1,18 - IGDS(I) = GRD205(I) - 290 CONTINUE -C - ELSE IF (IGRID.EQ.206) THEN - DO 300 I = 1,18 - IGDS(I) = GRD206(I) - 300 CONTINUE -C - ELSE IF (IGRID.EQ.207) THEN - DO 310 I = 1,18 - IGDS(I) = GRD207(I) - 310 CONTINUE -C - ELSE IF (IGRID.EQ.208) THEN - DO 320 I = 1,18 - IGDS(I) = GRD208(I) - 320 CONTINUE -C - ELSE IF (IGRID.EQ.209) THEN - DO 330 I = 1,18 - IGDS(I) = GRD209(I) - 330 CONTINUE -C - ELSE IF (IGRID.EQ.210) THEN - DO 340 I = 1,18 - IGDS(I) = GRD210(I) - 340 CONTINUE -C - ELSE IF (IGRID.EQ.211) THEN - DO 350 I = 1,18 - IGDS(I) = GRD211(I) - 350 CONTINUE -C - ELSE IF (IGRID.EQ.212) THEN - DO 360 I = 1,18 - IGDS(I) = GRD212(I) - 360 CONTINUE -C - ELSE IF (IGRID.EQ.213) THEN - DO 370 I = 1,18 - IGDS(I) = GRD213(I) - 370 CONTINUE -C - ELSE IF (IGRID.EQ.214) THEN - DO 380 I = 1,18 - IGDS(I) = GRD214(I) - 380 CONTINUE -C - ELSE IF (IGRID.EQ.215) THEN - DO 390 I = 1,18 - IGDS(I) = GRD215(I) - 390 CONTINUE -C - ELSE IF (IGRID.EQ.216) THEN - DO 400 I = 1,18 - IGDS(I) = GRD216(I) - 400 CONTINUE -C - ELSE IF (IGRID.EQ.217) THEN - DO 401 I = 1,18 - IGDS(I) = GRD217(I) - 401 CONTINUE -C - ELSE IF (IGRID.EQ.218) THEN - DO 410 I = 1,18 - IGDS(I) = GRD218(I) - 410 CONTINUE -C - ELSE IF (IGRID.EQ.219) THEN - DO 411 I = 1,18 - IGDS(I) = GRD219(I) - 411 CONTINUE -C - ELSE IF (IGRID.EQ.220) THEN - DO 412 I = 1,18 - IGDS(I) = GRD220(I) - 412 CONTINUE -C - ELSE IF (IGRID.EQ.221) THEN - DO 413 I = 1,18 - IGDS(I) = GRD221(I) - 413 CONTINUE -C - ELSE IF (IGRID.EQ.222) THEN - DO 414 I = 1,18 - IGDS(I) = GRD222(I) - 414 CONTINUE -C - ELSE IF (IGRID.EQ.223) THEN - DO 415 I = 1,18 - IGDS(I) = GRD223(I) - 415 CONTINUE -C - ELSE IF (IGRID.EQ.224) THEN - DO 416 I = 1,18 - IGDS(I) = GRD224(I) - 416 CONTINUE -C - ELSE IF (IGRID.EQ.225) THEN - DO 417 I = 1,18 - IGDS(I) = GRD225(I) - 417 CONTINUE -C - ELSE IF (IGRID.EQ.226) THEN - DO 418 I = 1,18 - IGDS(I) = GRD226(I) - 418 CONTINUE -C - ELSE IF (IGRID.EQ.227) THEN - DO 419 I = 1,18 - IGDS(I) = GRD227(I) - 419 CONTINUE -C - ELSE IF (IGRID.EQ.228) THEN - DO 420 I = 1,18 - IGDS(I) = GRD228(I) - 420 CONTINUE -C - ELSE IF (IGRID.EQ.229) THEN - DO 421 I = 1,18 - IGDS(I) = GRD229(I) - 421 CONTINUE -C - ELSE IF (IGRID.EQ.230) THEN - DO 422 I = 1,18 - IGDS(I) = GRD230(I) - 422 CONTINUE -C - ELSE IF (IGRID.EQ.231) THEN - DO 423 I = 1,18 - IGDS(I) = GRD231(I) - 423 CONTINUE -C - ELSE IF (IGRID.EQ.232) THEN - DO 424 I = 1,18 - IGDS(I) = GRD232(I) - 424 CONTINUE -C - ELSE IF (IGRID.EQ.233) THEN - DO 425 I = 1,18 - IGDS(I) = GRD233(I) - 425 CONTINUE -C - ELSE IF (IGRID.EQ.234) THEN - DO 426 I = 1,18 - IGDS(I) = GRD234(I) - 426 CONTINUE -C - ELSE IF (IGRID.EQ.235) THEN - DO 427 I = 1,18 - IGDS(I) = GRD235(I) - 427 CONTINUE -C - ELSE IF (IGRID.EQ.236) THEN - DO 428 I = 1,18 - IGDS(I) = GRD236(I) - 428 CONTINUE -C - ELSE IF (IGRID.EQ.237) THEN - DO 429 I = 1,18 - IGDS(I) = GRD237(I) - 429 CONTINUE -C - ELSE IF (IGRID.EQ.238) THEN - DO I = 1,18 - IGDS(I) = GRD238(I) - END DO -C - ELSE IF (IGRID.EQ.239) THEN - DO I = 1,18 - IGDS(I) = GRD239(I) - END DO -C - ELSE IF (IGRID.EQ.240) THEN - DO I = 1,18 - IGDS(I) = GRD240(I) - END DO -C - ELSE IF (IGRID.EQ.241) THEN - DO 430 I = 1,18 - IGDS(I) = GRD241(I) - 430 CONTINUE -C - ELSE IF (IGRID.EQ.242) THEN - DO 431 I = 1,18 - IGDS(I) = GRD242(I) - 431 CONTINUE -C - ELSE IF (IGRID.EQ.243) THEN - DO 432 I = 1,18 - IGDS(I) = GRD243(I) - 432 CONTINUE -C - ELSE IF (IGRID.EQ.244) THEN - DO I = 1,18 - IGDS(I) = GRD244(I) - END DO -C - ELSE IF (IGRID.EQ.245) THEN - DO 433 I = 1,18 - IGDS(I) = GRD245(I) - 433 CONTINUE -C - ELSE IF (IGRID.EQ.246) THEN - DO 434 I = 1,18 - IGDS(I) = GRD246(I) - 434 CONTINUE -C - ELSE IF (IGRID.EQ.247) THEN - DO 435 I = 1,18 - IGDS(I) = GRD247(I) - 435 CONTINUE -C - ELSE IF (IGRID.EQ.248) THEN - DO 436 I = 1,18 - IGDS(I) = GRD248(I) - 436 CONTINUE -C - ELSE IF (IGRID.EQ.249) THEN - DO 437 I = 1,18 - IGDS(I) = GRD249(I) - 437 CONTINUE -C - ELSE IF (IGRID.EQ.250) THEN - DO 438 I = 1,18 - IGDS(I) = GRD250(I) - 438 CONTINUE -C - ELSE IF (IGRID.EQ.251) THEN - DO 439 I = 1,18 - IGDS(I) = GRD251(I) - 439 CONTINUE -C - ELSE IF (IGRID.EQ.252) THEN - DO 440 I = 1,18 - IGDS(I) = GRD252(I) - 440 CONTINUE - ELSE IF (IGRID.EQ.253) THEN - DO 441 I = 1,18 - IGDS(I) = GRD253(I) - 441 CONTINUE - ELSE IF (IGRID.EQ.254) THEN - DO 442 I = 1,18 - IGDS(I) = GRD254(I) - 442 CONTINUE -C - ELSE - IERR = 1 - ENDIF -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi72.f b/external/w3nco/v2.0.6/src/w3fi72.f deleted file mode 100644 index 5797f2f19..000000000 --- a/external/w3nco/v2.0.6/src/w3fi72.f +++ /dev/null @@ -1,455 +0,0 @@ - SUBROUTINE W3FI72(ITYPE,FLD,IFLD,IBITL, - & IPFLAG,ID,PDS, - & IGFLAG,IGRID,IGDS,ICOMP, - & IBFLAG,IBMAP,IBLEN,IBDSFL, - & NPTS,KBUF,ITOT,JERR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI72 MAKE A COMPLETE GRIB MESSAGE -C PRGMMR: FARLEY ORG: NMC421 DATE:94-11-22 -C -C ABSTRACT: MAKES A COMPLETE GRIB MESSAGE FROM A USER SUPPLIED -C ARRAY OF FLOATING POINT OR INTEGER DATA. THE USER HAS THE -C OPTION OF SUPPLYING THE PDS OR AN INTEGER ARRAY THAT WILL BE -C USED TO CREATE A PDS (WITH W3FI68). THE USER MUST ALSO -C SUPPLY OTHER NECESSARY INFO; SEE USAGE SECTION BELOW. -C -C PROGRAM HISTORY LOG: -C 91-05-08 R.E.JONES -C 92-07-01 M. FARLEY ADDED GDS AND BMS LOGIC. PLACED EXISTING -C LOGIC FOR BDS IN A ROUTINE. -C 92-10-02 R.E.JONES ADD ERROR EXIT FOR W3FI73 -C 93-04-30 R.E.JONES REPLACE DO LOOPS TO MOVE CHARACTER DATA -C WITH XMOVEX, USE XSTORE TO ZERO CHARACTER -C ARRAY. MAKE CHANGE SO FLAT FIELD WILL PACK. -C 93-08-06 CAVANAUGH MODIFIED CALL TO W3FI75 -C 93-10-26 CAVANAUGH ADDED CODE TO RESTORE INPUT FIELD TO ORIGINAL -C VALUES IF D-SCALE NOT 0 -C 94-01-27 CAVANAUGH ADDED IGDS ARRAY IN CALL TO W3FI75 TO PROVIDE -C INFORMATION FOR BOUSTROPHEDONIC PROCESSING -C 94-03-03 CAVANAUGH INCREASED SIZE OF GDS ARRAY FOR THIN GRIDS -C 94-05-16 FARLEY CLEANED UP DOCUMENTATION -C 94-11-10 FARLEY INCREASED SIZE OF PFLD/IFLD ARRARYS FROM -C 100K TO 260K FOR .5 DEGREE SST ANAL FIELDS -C 94-12-04 R.E.JONES CHANGE DOCUMENT FOR IPFLAG. -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-05-19 Gilbert Increased array dimensions to handle grids -C of up to 500,000 grid points. -C 95-10-31 IREDELL GENERALIZED WORD SIZE -C 98-12-21 Gilbert Replaced Function ICHAR with mova2i. -C 99-02-01 Gilbert Changed the method of zeroing out array KBUF. -C the old method, using W3FI01 and XSTORE was -C incorrect with 4-byte integers and 8-byte reals. -C 2001-06-07 Gilbert Removed calls to xmovex. -C changed IPFLD from integer to character. -C 10-02-19 GAYNO FIX ALLOCATION OF ARRAY BMS -C -C USAGE: CALL W3FI72(ITYPE,FLD,IFLD,IBITL, -C & IPFLAG,ID,PDS, -C & IGFLAG,IGRID,IGDS,ICOMP, -C & IBFLAG,IBMAP,IBLEN,IBDSFL, -C & IBDSFL, -C & NPTS,KBUF,ITOT,JERR) -C -C INPUT ARGUMENT LIST: -C ITYPE - 0 = FLOATING POINT DATA SUPPLIED IN ARRAY 'FLD' -C 1 = INTEGER DATA SUPPLIED IN ARRAY 'IFLD' -C FLD - REAL ARRAY OF DATA (AT PROPER GRIDPOINTS) TO BE -C CONVERTED TO GRIB FORMAT IF ITYPE=0. -C SEE REMARKS #1 & 2. -C IFLD - INTEGER ARRAY OF DATA (AT PROPER GRIDPOINTS) TO BE -C CONVERTED TO GRIB FORMAT IF ITYPE=1. -C SEE REMARKS #1 & 2. -C IBITL - 0 = COMPUTER COMPUTES LENGTH FOR PACKING DATA FROM -C POWER OF 2 (NUMBER OF BITS) BEST FIT OF DATA -C USING 'VARIABLE' BIT PACKER W3FI58. -C 8, 12, ETC. COMPUTER RESCALES DATA TO FIT INTO THAT -C 'FIXED' NUMBER OF BITS USING W3FI59. -C SEE REMARKS #3. -C -C IPFLAG - 0 = MAKE PDS FROM USER SUPPLIED ARRAY (ID) -C 1 = USER SUPPLYING PDS -C NOTE: IF PDS IS GREATER THAN 30, USE IPLFAG=1. -C THE USER COULD CALL W3FI68 BEFORE HE CALLS -C W3FI72. THIS WOULD MAKE THE FIRST 30 BYTES OF -C THE PDS, USER THEN WOULD MAKE BYTES AFTER 30. -C ID - INTEGER ARRAY OF VALUES THAT W3FI68 WILL USE -C TO MAKE AN EDITION 1 PDS IF IPFLAG=0. (SEE THE -C DOCBLOCK FOR W3FI68 FOR LAYOUT OF ARRAY) -C PDS - CHARACTER ARRAY OF VALUES (VALID PDS SUPPLIED -C BY USER) IF IPFLAG=1. LENGTH MAY EXCEED 28 BYTES -C (CONTENTS OF BYTES BEYOND 28 ARE PASSED -C THROUGH UNCHANGED). -C -C IGFLAG - 0 = MAKE GDS BASED ON 'IGRID' VALUE. -C 1 = MAKE GDS FROM USER SUPPLIED INFO IN 'IGDS' -C AND 'IGRID' VALUE. -C SEE REMARKS #4. -C IGRID - # = GRID IDENTIFICATION (TABLE B) -C 255 = IF USER DEFINED GRID; IGDS MUST BE SUPPLIED -C AND IGFLAG MUST =1. -C IGDS - INTEGER ARRAY CONTAINING USER GDS INFO (SAME -C FORMAT AS SUPPLIED BY W3FI71 - SEE DOCKBLOCK FOR -C LAYOUT) IF IGFLAG=1. -C ICOMP - RESOLUTION AND COMPONENT FLAG FOR BIT 5 OF GDS(17) -C 0 = EARTH ORIENTED WINDS -C 1 = GRID ORIENTED WINDS -C -C IBFLAG - 0 = MAKE BIT MAP FROM USER SUPPLIED DATA -C # = BIT MAP PREDEFINED BY CENTER -C SEE REMARKS #5. -C IBMAP - INTEGER ARRAY CONTAINING BIT MAP -C IBLEN - LENGTH OF BIT MAP WILL BE USED TO VERIFY LENGTH -C OF FIELD (ERROR IF IT DOESN'T MATCH). -C -C IBDSFL - INTEGER ARRAY CONTAINING TABLE 11 FLAG INFO -C BDS OCTET 4: -C (1) 0 = GRID POINT DATA -C 1 = SPHERICAL HARMONIC COEFFICIENTS -C (2) 0 = SIMPLE PACKING -C 1 = SECOND ORDER PACKING -C (3) ... SAME VALUE AS 'ITYPE' -C 0 = ORIGINAL DATA WERE FLOATING POINT VALUES -C 1 = ORIGINAL DATA WERE INTEGER VALUES -C (4) 0 = NO ADDITIONAL FLAGS AT OCTET 14 -C 1 = OCTET 14 CONTAINS FLAG BITS 5-12 -C (5) 0 = RESERVED - ALWAYS SET TO 0 -C BYTE 6 OPTION 1 NOT AVAILABLE (AS OF 5-16-93) -C (6) 0 = SINGLE DATUM AT EACH GRID POINT -C 1 = MATRIX OF VALUES AT EACH GRID POINT -C BYTE 7 OPTION 0 WITH SECOND ORDER PACKING N/A (AS OF 5-16-93) -C (7) 0 = NO SECONDARY BIT MAPS -C 1 = SECONDARY BIT MAPS PRESENT -C (8) 0 = SECOND ORDER VALUES HAVE CONSTANT WIDTH -C 1 = SECOND ORDER VALUES HAVE DIFFERENT WIDTHS -C -C OUTPUT ARGUMENT LIST: -C NPTS - NUMBER OF GRIDPOINTS IN ARRAY FLD OR IFLD -C KBUF - ENTIRE GRIB MESSAGE ('GRIB' TO '7777') -C EQUIVALENCE TO INTEGER ARRAY TO MAKE SURE IT -C IS ON WORD BOUNARY. -C ITOT - TOTAL LENGTH OF GRIB MESSAGE IN BYTES -C JERR - = 0, COMPLETED MAKING GRIB FIELD WITHOUT ERROR -C 1, IPFLAG NOT 0 OR 1 -C 2, IGFLAG NOT 0 OR 1 -C 3, ERROR CONVERTING IEEE F.P. NUMBER TO IBM370 F.P. -C 4, W3FI71 ERROR/IGRID NOT DEFINED -C 5, W3FK74 ERROR/GRID REPRESENTATION TYPE NOT VALID -C 6, GRID TOO LARGE FOR PACKER DIMENSION ARRAYS -C SEE AUTOMATION DIVISION FOR REVISION! -C 7, LENGTH OF BIT MAP NOT EQUAL TO SIZE OF FLD/IFLD -C 8, W3FI73 ERROR, ALL VALUES IN IBMAP ARE ZERO -C -C OUTPUT FILES: -C FT06F001 - STANDARD FORTRAN OUTPUT PRINT FILE -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - W3FI58, W3FI59, W3FI68, W3FI71, W3FI73, W3FI74 -C W3FI75, W3FI76 -C FORTRAN 90 INTRINSIC - BIT_SIZE -C -C REMARKS: -C 1) IF BIT MAP TO BE INCLUDED IN MESSAGE, NULL DATA SHOULD -C BE INCLUDED IN FLD OR IFLD. THIS ROUTINE WILL TAKE CARE -C OF 'DISCARDING' ANY NULL DATA BASED ON THE BIT MAP. -C 2) UNITS MUST BE THOSE IN GRIB DOCUMENTATION: NMC O.N. 388 -C OR WMO PUBLICATION 306. -C 3) IN EITHER CASE, INPUT NUMBERS WILL BE MULTIPLIED BY -C '10 TO THE NTH' POWER FOUND IN ID(25) OR PDS(27-28), -C THE D-SCALING FACTOR, PRIOR TO BINARY PACKING. -C 4) ALL NMC PRODUCED GRIB FIELDS WILL HAVE A GRID DEFINITION -C SECTION INCLUDED IN THE GRIB MESSAGE. ID(6) WILL BE -C SET TO '1'. -C - GDS WILL BE BUILT BASED ON GRID NUMBER (IGRID), UNLESS -C IGFLAG=1 (USER SUPPLYING IGDS). USER MUST STILL SUPPLY -C IGRID EVEN IF IGDS PROVIDED. -C 5) IF BIT MAP USED THEN ID(7) OR PDS(8) MUST INDICATE THE -C PRESENCE OF A BIT MAP. -C 6) ARRAY KBUF SHOULD BE EQUIVALENCED TO AN INTEGER VALUE OR -C ARRAY TO MAKE SURE IT IS ON A WORD BOUNDARY. -C 7) SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -C - REAL FLD(*) -C - INTEGER IBDSFL(*) - INTEGER IBMAP(*) - INTEGER ID(*) - INTEGER IFLD(*) - INTEGER IGDS(*) - INTEGER IB(4) - INTEGER NLEFT, NUMBMS -C - CHARACTER * 1 BDS11(11) - CHARACTER * 1 KBUF(*) - CHARACTER * 1 PDS(*) - CHARACTER * 1 GDS(200) - CHARACTER(1),ALLOCATABLE:: BMS(:) - CHARACTER(1),ALLOCATABLE:: PFLD(:) - CHARACTER(1),ALLOCATABLE:: IPFLD(:) - CHARACTER * 1 SEVEN - CHARACTER * 1 ZERO -C -C -C ASCII REP OF /'G', 'R', 'I', 'B'/ -C - DATA IB / 71, 82, 73, 66/ -C - IER = 0 - IBERR = 0 - JERR = 0 - IGRIBL = 8 - IPDSL = 0 - LENGDS = 0 - LENBMS = 0 - LENBDS = 0 - ITOSS = 0 -C -C 1.0 PRODUCT DEFINITION SECTION(PDS). -C -C SET ID(6) TO 1 ...OR... MODIFY PDS(8) ... -C REGARDLESS OF USER SPECIFICATION... -C NMC GRIB FIELDS WILL ALWAYS HAVE A GDS -C - IF (IPFLAG .EQ.0) THEN - ID(6) = 1 - CALL W3FI68(ID,PDS) - ELSE IF (IPFLAG .EQ. 1) THEN - IF (IAND(mova2i(PDS(8)),64) .EQ. 64) THEN -C BOTH GDS AND BMS - PDS(8) = CHAR(192) - ELSE IF (mova2i(PDS(8)) .EQ. 0) THEN -C GDS ONLY - PDS(8) = CHAR(128) - END IF - CONTINUE - ELSE -C PRINT *,' W3FI72 ERROR, IPFLAG IS NOT 0 OR 1 IPFLAG = ',IPFLAG - JERR = 1 - GO TO 900 - END IF -C -C GET LENGTH OF PDS -C - IPDSL = mova2i(PDS(1)) * 65536 + mova2i(PDS(2)) * 256 + - & mova2i(PDS(3)) -C -C 2.0 GRID DEFINITION SECTION (GDS). -C -C IF IGFLAG=1 THEN USER IS SUPPLYING THE IGDS INFORMATION -C - IF (IGFLAG .EQ. 0) THEN - CALL W3FI71(IGRID,IGDS,IGERR) - IF (IGERR .EQ. 1) THEN -C PRINT *,' W3FI71 ERROR, GRID TYPE NOT DEFINED...',IGRID - JERR = 4 - GO TO 900 - END IF - END IF - IF (IGFLAG .EQ. 0 .OR. IGFLAG .EQ.1) THEN - CALL W3FI74(IGDS,ICOMP,GDS,LENGDS,NPTS,IGERR) - IF (IGERR .EQ. 1) THEN -C PRINT *,' W3FI74 ERROR, GRID REP TYPE NOT VALID...',IGDS(3) - JERR = 5 - GO TO 900 - ELSE - END IF - ELSE -C PRINT *,' W3FI72 ERROR, IGFLAG IS NOT 0 OR 1 IGFLAG = ',IGFLAG - JERR = 2 - GO TO 900 - END IF -C -C 3.0 BIT MAP SECTION (BMS). -C -C SET ITOSS=1 IF BITMAP BEING USED. W3FI75 WILL TOSS DATA -C PRIOR TO PACKING. LATER CODING WILL BE NEEDED WHEN THE -C 'PREDEFINED' GRIDS ARE FINALLY 'DEFINED'. -C - IF (mova2i(PDS(8)) .EQ. 64 .OR. - & mova2i(PDS(8)) .EQ. 192) THEN - ITOSS = 1 - IF (IBFLAG .EQ. 0) THEN - IF (IBLEN .NE. NPTS) THEN -C PRINT *,' W3FI72 ERROR, IBLEN .NE. NPTS = ',IBLEN,NPTS - JERR = 7 - GO TO 900 - END IF - IF (MOD(IBLEN,16).NE.0) THEN - NLEFT = 16 - MOD(IBLEN,16) - ELSE - NLEFT = 0 - END IF - NUMBMS = 6 + (IBLEN+NLEFT) / 8 - ALLOCATE(BMS(NUMBMS)) - ZERO = CHAR(00) - BMS = ZERO - CALL W3FI73(IBFLAG,IBMAP,IBLEN,BMS,LENBMS,IER) - IF (IER .NE. 0) THEN -C PRINT *,' W3FI73 ERROR, IBMAP VALUES ARE ALL ZERO' - JERR = 8 - GO TO 900 - END IF - ELSE -C PRINT *,' BIT MAP PREDEFINED BY CENTER, IBFLAG = ',IBFLAG - END IF - END IF -C -C 4.0 BINARY DATA SECTION (BDS). -C -C 4.1 SCALE THE DATA WITH D-SCALE FROM PDS(27-28) -C - JSCALE = mova2i(PDS(27)) * 256 + mova2i(PDS(28)) - IF (IAND(JSCALE,32768).NE.0) THEN - JSCALE = - IAND(JSCALE,32767) - END IF - SCALE = 10.0 ** JSCALE - IF (ITYPE .EQ. 0) THEN - DO 410 I = 1,NPTS - FLD(I) = FLD(I) * SCALE - 410 CONTINUE - ELSE - DO 411 I = 1,NPTS - IFLD(I) = NINT(FLOAT(IFLD(I)) * SCALE) - 411 CONTINUE - END IF -C -C 4.2 CALL W3FI75 TO PACK DATA AND MAKE BDS. -C - ALLOCATE(PFLD(NPTS*4)) -C - IF(IBDSFL(2).NE.0) THEN - ALLOCATE(IPFLD(NPTS*4)) - IPFLD=char(0) - ELSE - ALLOCATE(IPFLD(1)) - ENDIF -C - CALL W3FI75(IBITL,ITYPE,ITOSS,FLD,IFLD,IBMAP,IBDSFL, - & NPTS,BDS11,IPFLD,PFLD,LEN,LENBDS,IBERR,PDS,IGDS) -C - IF(IBDSFL(2).NE.0) THEN -C CALL XMOVEX(PFLD,IPFLD,NPTS*4) - do ii = 1, NPTS*4 - PFLD(ii) = IPFLD(ii) - enddo - ENDIF - DEALLOCATE(IPFLD) -C - IF (IBERR .EQ. 1) THEN - JERR = 3 - GO TO 900 - END IF -C 4.3 IF D-SCALE NOT 0, RESCALE INPUT FIELD TO -C ORIGINAL VALUE -C - IF (JSCALE.NE.0) THEN - DSCALE = 1.0 / SCALE - IF (ITYPE.EQ.0) THEN - DO 412 I = 1, NPTS - FLD(I) = FLD(I) * DSCALE - 412 CONTINUE - ELSE - DO 413 I = 1, NPTS - FLD(I) = NINT(FLOAT(IFLD(I)) * DSCALE) - 413 CONTINUE - END IF - END IF -C -C 5.0 OUTPUT SECTION. -C -C 5.1 ZERO OUT THE OUTPUT ARRAY KBUF. -C - ZERO = CHAR(00) - ITOT = IGRIBL + IPDSL + LENGDS + LENBMS + LENBDS + 4 -C PRINT *,'IGRIBL =',IGRIBL -C PRINT *,'IPDSL =',IPDSL -C PRINT *,'LENGDS =',LENGDS -C PRINT *,'LENBMS =',LENBMS -C PRINT *,'LENBDS =',LENBDS -C PRINT *,'ITOT =',ITOT - KBUF(1:ITOT)=ZERO -C -C 5.2 MOVE SECTION 0 - 'IS' INTO KBUF (8 BYTES). -C - ISTART = 0 - DO 520 I = 1,4 - KBUF(I) = CHAR(IB(I)) - 520 CONTINUE -C - KBUF(5) = CHAR(MOD(ITOT / 65536,256)) - KBUF(6) = CHAR(MOD(ITOT / 256,256)) - KBUF(7) = CHAR(MOD(ITOT ,256)) - KBUF(8) = CHAR(1) -C -C 5.3 MOVE SECTION 1 - 'PDS' INTO KBUF (28 BYTES). -C - ISTART = ISTART + IGRIBL - IF (IPDSL.GT.0) THEN -C CALL XMOVEX(KBUF(ISTART+1),PDS,IPDSL) - do ii = 1, IPDSL - KBUF(ISTART+ii) = PDS(ii) - enddo - ELSE -C PRINT *,'LENGTH OF PDS LESS OR EQUAL 0, IPDSL = ',IPDSL - END IF -C -C 5.4 MOVE SECTION 2 - 'GDS' INTO KBUF. -C - ISTART = ISTART + IPDSL - IF (LENGDS .GT. 0) THEN -C CALL XMOVEX(KBUF(ISTART+1),GDS,LENGDS) - do ii = 1, LENGDS - KBUF(ISTART+ii) = GDS(ii) - enddo - END IF -C -C 5.5 MOVE SECTION 3 - 'BMS' INTO KBUF. -C - ISTART = ISTART + LENGDS - IF (LENBMS .GT. 0) THEN -C CALL XMOVEX(KBUF(ISTART+1),BMS,LENBMS) - do ii = 1, LENBMS - KBUF(ISTART+ii) = BMS(ii) - enddo - END IF -C -C 5.6 MOVE SECTION 4 - 'BDS' INTO KBUF. -C -C MOVE THE FIRST 11 OCTETS OF THE BDS INTO KBUF. -C - ISTART = ISTART + LENBMS -C CALL XMOVEX(KBUF(ISTART+1),BDS11,11) - do ii = 1, 11 - KBUF(ISTART+ii) = BDS11(ii) - enddo -C -C MOVE THE PACKED DATA INTO THE KBUF -C - ISTART = ISTART + 11 - IF (LEN.GT.0) THEN -C CALL XMOVEX(KBUF(ISTART+1),PFLD,LEN) - do ii = 1, LEN - KBUF(ISTART+ii) = PFLD(ii) - enddo - END IF -C -C ADD '7777' TO END OFF KBUF -C NOTE THAT THESE 4 OCTETS NOT INCLUDED IN ACTUAL SIZE OF BDS. -C - SEVEN = CHAR(55) - ISTART = ITOT - 4 - DO 562 I = 1,4 - KBUF(ISTART+I) = SEVEN - 562 CONTINUE -C - 900 CONTINUE - IF(ALLOCATED(BMS)) DEALLOCATE(BMS) - IF(ALLOCATED(PFLD)) DEALLOCATE(PFLD) - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi73.f b/external/w3nco/v2.0.6/src/w3fi73.f deleted file mode 100644 index 629373c8c..000000000 --- a/external/w3nco/v2.0.6/src/w3fi73.f +++ /dev/null @@ -1,100 +0,0 @@ - SUBROUTINE W3FI73 (IBFLAG,IBMAP,IBLEN,BMS,LENBMS,IER) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI73 CONSTRUCT GRIB BIT MAP SECTION (BMS) -C PRGMMR: FARLEY ORG: NMC421 DATE:92-11-16 -C -C ABSTRACT: THIS SUBROUTINE CONSTRUCTS A GRIB BIT MAP SECTION. -C -C PROGRAM HISTORY LOG: -C 92-07-01 M. FARLEY ORIGINAL AUTHOR -C 94-02-14 CAVANAUGH RECODED -C 98-06-30 EBISUZAKI LINUX PORT -C -C USAGE: CALL W3FI73 (IBFLAG, IBMAP, IBLEN, BMS, LENBMS, IER) -C INPUT ARGUMENT LIST: -C IBFLAG - 0, IF BIT MAP SUPPLIED BY USER -C - #, NUMBER OF PREDEFINED CENTER BIT MAP -C IBMAP - INTEGER ARRAY CONTAINING USER BIT MAP -C IBLEN - LENGTH OF BIT MAP -C -C OUTPUT ARGUMENT LIST: -C BMS - COMPLETED GRIB BIT MAP SECTION -C LENBMS - LENGTH OF BIT MAP SECTION -C IER - 0 NORMAL EXIT, 8 = IBMAP VALUES ARE ALL ZERO -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - SBYTE -C -C ATTRIBUTES: -C LANGUAGE: IBM370 VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, CRAY J916/2048 -C -C$$$ -C - INTEGER IBMAP(*) - INTEGER LENBMS - INTEGER IBLEN - INTEGER IBFLAG -C - CHARACTER*1 BMS(*) -C - IER = 0 -C - IZ = 0 - DO 20 I = 1, IBLEN - IF (IBMAP(I).EQ.0) IZ = IZ + 1 - 20 CONTINUE - IF (IZ.EQ.IBLEN) THEN -C -C AT THIS POINT ALL BIT MAP POSITIONS ARE ZERO -C - IER = 8 - RETURN - END IF -C -C BIT MAP IS A COMBINATION OF ONES AND ZEROS -C OR BIT MAP ALL ONES -C -C CONSTRUCT BIT MAP FIELD OF BIT MAP SECTION -C - CALL SBYTESC(BMS,IBMAP,48,1,0,IBLEN) -C - IF (MOD(IBLEN,16).NE.0) THEN - NLEFT = 16 - MOD(IBLEN,16) - ELSE - NLEFT = 0 - END IF -C - NUM = 6 + (IBLEN+NLEFT) / 8 -C -C CONSTRUCT BMS FROM COLLECTED DATA -C -C SIZE INTO FIRST THREE BYTES -C - CALL SBYTEC(BMS,NUM,0,24) -C NUMBER OF FILL BITS INTO BYTE 4 - CALL SBYTEC(BMS,NLEFT,24,8) -C OCTET 5-6 TO CONTAIN INFO FROM IBFLAG - CALL SBYTEC(BMS,IBFLAG,32,16) -C -C BIT MAP MAY BE ALL ONES OR A COMBINATION -C OF ONES AND ZEROS -C -C ACTUAL BITS OF BIT MAP PLACED ALL READY -C -C INSTALL FILL POSITIONS IF NEEDED - IF (NLEFT.NE.0) THEN - NLEFT = 16 - NLEFT -C ZERO FILL POSITIONS - CALL SBYTEC(BMS,0,IBLEN+48,NLEFT) - END IF -C -C STORE NUM IN LENBMS (LENGTH OF BMS SECTION) -C - LENBMS = NUM -C PRINT *,'W3FI73 - BMS LEN =',NUM,LENBMS -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi74.f b/external/w3nco/v2.0.6/src/w3fi74.f deleted file mode 100644 index 8cc06dd64..000000000 --- a/external/w3nco/v2.0.6/src/w3fi74.f +++ /dev/null @@ -1,426 +0,0 @@ - SUBROUTINE W3FI74 (IGDS,ICOMP,GDS,LENGDS,NPTS,IGERR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI74 CONSTRUCT GRID DEFINITION SECTION (GDS) -C PRGMMR: FARLEY ORG: W/NMC42 DATE: 93-08-24 -C -C ABSTRACT: THIS SUBROUTINE CONSTRUCTS A GRIB GRID DEFINITION -C SECTION. -C -C PROGRAM HISTORY LOG: -C 92-07-07 M. FARLEY ORIGINAL AUTHOR -C 92-10-16 R.E.JONES ADD CODE TO LAT/LON SECTION TO DO -C GAUSSIAN GRIDS. -C 93-03-29 R.E.JONES ADD SAVE STATEMENT -C 93-08-24 R.E.JONES CHANGES FOR GRIB GRIDS 37-44 -C 93-09-29 R.E.JONES CHANGES FOR GAUSSIAN GRID FOR DOCUMENT -C CHANGE IN W3FI71. -C 94-02-15 R.E.JONES CHANGES FOR ETA MODEL GRIDS 90-93 -C 95-04-20 R.E.JONES CHANGE 200 AND 201 TO 201 AND 202 -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-08-20 BALDWIN ADD TYPE 203 -C 07-03-20 VUONG ADD TYPE 204 -C 10-01-21 GAYNO ADD GRID 205 - ROTATED LAT/LON A,B,C,D STAGGERS -C -C -C USAGE: CALL W3FI74 (IGDS, ICOMP, GDS, LENGDS, NPTS, IGERR) -C INPUT ARGUMENT LIST: -C IGDS - INTEGER ARRAY SUPPLIED BY W3FI71 -C ICOMP - TABLE 7- RESOLUTION & COMPONENT FLAG (BIT 5) -C FOR GDS(17) WIND COMPONENTS -C -C OUTPUT ARGUMENT LIST: -C GDS - COMPLETED GRIB GRID DEFINITION SECTION -C LENGDS - LENGTH OF GDS -C NPTS - NUMBER OF POINTS IN GRID -C IGERR - 1, GRID REPRESENTATION TYPE NOT VALID -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN 77, IBM370 VS FORTRAN -C MACHINE: CRAY C916-128, CRAY Y-MP8/864, CRAY Y-MP EL2/256, HDS -C -C$$$ -C - INTEGER IGDS (*) -C - CHARACTER*1 GDS (*) -C - ISUM = 0 - IGERR = 0 -C -C PRINT *,' ' -C PRINT *,'(W3FI74-IGDS = )' -C PRINT *,(IGDS(I),I=1,18) -C PRINT *,' ' -C -C COMPUTE LENGTH OF GDS IN OCTETS (OCTETS 1-3) -C LENGDS = 32 FOR LAT/LON, GNOMIC, GAUSIAN LAT/LON, -C POLAR STEREOGRAPHIC, SPHERICAL HARMONICS, -C ROTATED LAT/LON E-STAGGER -C LENGDS = 34 ROTATED LAT/LON A,B,C,D STAGGERS -C LENGDS = 42 FOR MERCATOR, LAMBERT, TANGENT CONE -C LENGDS = 178 FOR MERCATOR, LAMBERT, TANGENT CONE -C - IF (IGDS(3) .EQ. 0 .OR. IGDS(3) .EQ. 2 .OR. - & IGDS(3) .EQ. 4 .OR. IGDS(3) .EQ. 5 .OR. - & IGDS(3) .EQ. 50 .OR. IGDS(3) .EQ. 201.OR. - & IGDS(3) .EQ. 202.OR. IGDS(3) .EQ. 203.OR. - & IGDS(3) .EQ. 204 ) THEN - LENGDS = 32 -C -C CORRECTION FOR GRIDS 37-44 -C - IF (IGDS(3).EQ.0.AND.IGDS(1).EQ.0.AND.IGDS(2).NE. - & 255) THEN - LENGDS = IGDS(5) * 2 + 32 - ENDIF - ELSE IF (IGDS(3) .EQ. 1 .OR. IGDS(3) .EQ. 3 .OR. - & IGDS(3) .EQ. 13) THEN - LENGDS = 42 - ELSE IF (IGDS(3) .EQ. 205) THEN - LENGDS = 34 - ELSE -C PRINT *,' W3FI74 ERROR, GRID REPRESENTATION TYPE NOT VALID' - IGERR = 1 - RETURN - ENDIF -C -C PUT LENGTH OF GDS SECTION IN BYTES 1,2,3 -C - GDS(1) = CHAR(MOD(LENGDS/65536,256)) - GDS(2) = CHAR(MOD(LENGDS/ 256,256)) - GDS(3) = CHAR(MOD(LENGDS ,256)) -C -C OCTET 4 = NV, NUMBER OF VERTICAL COORDINATE PARAMETERS -C OCTET 5 = PV, PL OR 255 -C OCTET 6 = DATA REPRESENTATION TYPE (TABLE 6) -C - GDS(4) = CHAR(IGDS(1)) - GDS(5) = CHAR(IGDS(2)) - GDS(6) = CHAR(IGDS(3)) -C -C FILL OCTET THE REST OF THE GDS BASED ON DATA REPRESENTATION -C TYPE (TABLE 6) -C -C$$ -C PROCESS ROTATED LAT/LON A,B,C,D STAGGERS -C - IF (IGDS(3).EQ.205) THEN - GDS( 7) = CHAR(MOD(IGDS(4)/256,256)) - GDS( 8) = CHAR(MOD(IGDS(4) ,256)) - GDS( 9) = CHAR(MOD(IGDS(5)/256,256)) - GDS(10) = CHAR(MOD(IGDS(5) ,256)) - LATO = IGDS(6) ! LAT OF FIRST POINT - IF (LATO .LT. 0) THEN - LATO = -LATO - LATO = IOR(LATO,8388608) - ENDIF - GDS(11) = CHAR(MOD(LATO/65536,256)) - GDS(12) = CHAR(MOD(LATO/ 256,256)) - GDS(13) = CHAR(MOD(LATO ,256)) - LONO = IGDS(7) ! LON OF FIRST POINT - IF (LONO .LT. 0) THEN - LONO = -LONO - LONO = IOR(LONO,8388608) - ENDIF - GDS(14) = CHAR(MOD(LONO/65536,256)) - GDS(15) = CHAR(MOD(LONO/ 256,256)) - GDS(16) = CHAR(MOD(LONO ,256)) - LATEXT = IGDS(9) ! CENTER LAT - IF (LATEXT .LT. 0) THEN - LATEXT = -LATEXT - LATEXT = IOR(LATEXT,8388608) - ENDIF - GDS(18) = CHAR(MOD(LATEXT/65536,256)) - GDS(19) = CHAR(MOD(LATEXT/ 256,256)) - GDS(20) = CHAR(MOD(LATEXT ,256)) - LONEXT = IGDS(10) ! CENTER LON - IF (LONEXT .LT. 0) THEN - LONEXT = -LONEXT - LONEXT = IOR(LONEXT,8388608) - ENDIF - GDS(21) = CHAR(MOD(LONEXT/65536,256)) - GDS(22) = CHAR(MOD(LONEXT/ 256,256)) - GDS(23) = CHAR(MOD(LONEXT ,256)) - GDS(24) = CHAR(MOD(IGDS(11)/256,256)) - GDS(25) = CHAR(MOD(IGDS(11) ,256)) - GDS(26) = CHAR(MOD(IGDS(12)/256,256)) - GDS(27) = CHAR(MOD(IGDS(12) ,256)) - GDS(28) = CHAR(IGDS(13)) - LATO = IGDS(14) ! LAT OF LAST POINT - IF (LATO .LT. 0) THEN - LATO = -LATO - LATO = IOR(LATO,8388608) - ENDIF - GDS(29) = CHAR(MOD(LATO/65536,256)) - GDS(30) = CHAR(MOD(LATO/ 256,256)) - GDS(31) = CHAR(MOD(LATO ,256)) - LONO = IGDS(15) ! LON OF LAST POINT - IF (LONO .LT. 0) THEN - LONO = -LONO - LONO = IOR(LONO,8388608) - ENDIF - GDS(32) = CHAR(MOD(LONO/65536,256)) - GDS(33) = CHAR(MOD(LONO/ 256,256)) - GDS(34) = CHAR(MOD(LONO ,256)) -C -C PROCESS LAT/LON GRID TYPES OR GAUSSIAN GRID OR ARAKAWA -C STAGGERED, SEMI-STAGGERED, OR FILLED E-GRIDS -C - ELSEIF (IGDS(3).EQ.0.OR.IGDS(3).EQ.4.OR. - & IGDS(3).EQ.201.OR.IGDS(3).EQ.202.OR. - & IGDS(3).EQ.203.OR.IGDS(3).EQ.204) THEN - GDS( 7) = CHAR(MOD(IGDS(4)/256,256)) - GDS( 8) = CHAR(MOD(IGDS(4) ,256)) - GDS( 9) = CHAR(MOD(IGDS(5)/256,256)) - GDS(10) = CHAR(MOD(IGDS(5) ,256)) - LATO = IGDS(6) - IF (LATO .LT. 0) THEN - LATO = -LATO - LATO = IOR(LATO,8388608) - ENDIF - GDS(11) = CHAR(MOD(LATO/65536,256)) - GDS(12) = CHAR(MOD(LATO/ 256,256)) - GDS(13) = CHAR(MOD(LATO ,256)) - LONO = IGDS(7) - IF (LONO .LT. 0) THEN - LONO = -LONO - LONO = IOR(LONO,8388608) - ENDIF - GDS(14) = CHAR(MOD(LONO/65536,256)) - GDS(15) = CHAR(MOD(LONO/ 256,256)) - GDS(16) = CHAR(MOD(LONO ,256)) - LATEXT = IGDS(9) - IF (LATEXT .LT. 0) THEN - LATEXT = -LATEXT - LATEXT = IOR(LATEXT,8388608) - ENDIF - GDS(18) = CHAR(MOD(LATEXT/65536,256)) - GDS(19) = CHAR(MOD(LATEXT/ 256,256)) - GDS(20) = CHAR(MOD(LATEXT ,256)) - LONEXT = IGDS(10) - IF (LONEXT .LT. 0) THEN - LONEXT = -LONEXT - LONEXT = IOR(LONEXT,8388608) - ENDIF - GDS(21) = CHAR(MOD(LONEXT/65536,256)) - GDS(22) = CHAR(MOD(LONEXT/ 256,256)) - GDS(23) = CHAR(MOD(LONEXT ,256)) - IRES = IAND(IGDS(8),128) - IF (IGDS(3).EQ.201.OR.IGDS(3).EQ.202.OR. - & IGDS(3).EQ.203.OR.IGDS(3).EQ.204) THEN - GDS(24) = CHAR(MOD(IGDS(11)/256,256)) - GDS(25) = CHAR(MOD(IGDS(11) ,256)) - ELSE IF (IRES.EQ.0) THEN - GDS(24) = CHAR(255) - GDS(25) = CHAR(255) - ELSE - GDS(24) = CHAR(MOD(IGDS(12)/256,256)) - GDS(25) = CHAR(MOD(IGDS(12) ,256)) - END IF - IF (IGDS(3).EQ.4) THEN - GDS(26) = CHAR(MOD(IGDS(11)/256,256)) - GDS(27) = CHAR(MOD(IGDS(11) ,256)) - ELSE IF (IGDS(3).EQ.201.OR.IGDS(3).EQ.202.OR. - & IGDS(3).EQ.203.OR.IGDS(3).EQ.204)THEN - GDS(26) = CHAR(MOD(IGDS(12)/256,256)) - GDS(27) = CHAR(MOD(IGDS(12) ,256)) - ELSE IF (IRES.EQ.0) THEN - GDS(26) = CHAR(255) - GDS(27) = CHAR(255) - ELSE - GDS(26) = CHAR(MOD(IGDS(11)/256,256)) - GDS(27) = CHAR(MOD(IGDS(11) ,256)) - END IF - GDS(28) = CHAR(IGDS(13)) - GDS(29) = CHAR(0) - GDS(30) = CHAR(0) - GDS(31) = CHAR(0) - GDS(32) = CHAR(0) - IF (LENGDS.GT.32) THEN - ISUM = 0 - I = 19 - DO 10 J = 33,LENGDS,2 - ISUM = ISUM + IGDS(I) - GDS(J) = CHAR(MOD(IGDS(I)/256,256)) - GDS(J+1) = CHAR(MOD(IGDS(I) ,256)) - I = I + 1 - 10 CONTINUE - END IF -C -C$$ PROCESS MERCATOR GRID TYPES -C - ELSE IF (IGDS(3) .EQ. 1) THEN - GDS( 7) = CHAR(MOD(IGDS(4)/256,256)) - GDS( 8) = CHAR(MOD(IGDS(4) ,256)) - GDS( 9) = CHAR(MOD(IGDS(5)/256,256)) - GDS(10) = CHAR(MOD(IGDS(5) ,256)) - LATO = IGDS(6) - IF (LATO .LT. 0) THEN - LATO = -LATO - LATO = IOR(LATO,8388608) - ENDIF - GDS(11) = CHAR(MOD(LATO/65536,256)) - GDS(12) = CHAR(MOD(LATO/ 256,256)) - GDS(13) = CHAR(MOD(LATO ,256)) - LONO = IGDS(7) - IF (LONO .LT. 0) THEN - LONO = -LONO - LONO = IOR(LONO,8388608) - ENDIF - GDS(14) = CHAR(MOD(LONO/65536,256)) - GDS(15) = CHAR(MOD(LONO/ 256,256)) - GDS(16) = CHAR(MOD(LONO ,256)) - LATEXT = IGDS(9) - IF (LATEXT .LT. 0) THEN - LATEXT = -LATEXT - LATEXT = IOR(LATEXT,8388608) - ENDIF - GDS(18) = CHAR(MOD(LATEXT/65536,256)) - GDS(19) = CHAR(MOD(LATEXT/ 256,256)) - GDS(20) = CHAR(MOD(LATEXT ,256)) - LONEXT = IGDS(10) - IF (LONEXT .LT. 0) THEN - LONEXT = -LONEXT - LONEXT = IOR(LONEXT,8388608) - ENDIF - GDS(21) = CHAR(MOD(LONEXT/65536,256)) - GDS(22) = CHAR(MOD(LONEXT/ 256,256)) - GDS(23) = CHAR(MOD(LONEXT ,256)) - GDS(24) = CHAR(MOD(IGDS(13)/65536,256)) - GDS(25) = CHAR(MOD(IGDS(13)/ 256,256)) - GDS(26) = CHAR(MOD(IGDS(13) ,256)) - GDS(27) = CHAR(0) - GDS(28) = CHAR(IGDS(14)) - GDS(29) = CHAR(MOD(IGDS(12)/65536,256)) - GDS(30) = CHAR(MOD(IGDS(12)/ 256,256)) - GDS(31) = CHAR(MOD(IGDS(12) ,256)) - GDS(32) = CHAR(MOD(IGDS(11)/65536,256)) - GDS(33) = CHAR(MOD(IGDS(11)/ 256,256)) - GDS(34) = CHAR(MOD(IGDS(11) ,256)) - GDS(35) = CHAR(0) - GDS(36) = CHAR(0) - GDS(37) = CHAR(0) - GDS(38) = CHAR(0) - GDS(39) = CHAR(0) - GDS(40) = CHAR(0) - GDS(41) = CHAR(0) - GDS(42) = CHAR(0) -C$$ PROCESS LAMBERT CONFORMAL GRID TYPES - ELSE IF (IGDS(3) .EQ. 3) THEN - GDS( 7) = CHAR(MOD(IGDS(4)/256,256)) - GDS( 8) = CHAR(MOD(IGDS(4) ,256)) - GDS( 9) = CHAR(MOD(IGDS(5)/256,256)) - GDS(10) = CHAR(MOD(IGDS(5) ,256)) - LATO = IGDS(6) - IF (LATO .LT. 0) THEN - LATO = -LATO - LATO = IOR(LATO,8388608) - ENDIF - GDS(11) = CHAR(MOD(LATO/65536,256)) - GDS(12) = CHAR(MOD(LATO/ 256,256)) - GDS(13) = CHAR(MOD(LATO ,256)) - LONO = IGDS(7) - IF (LONO .LT. 0) THEN - LONO = -LONO - LONO = IOR(LONO,8388608) - ENDIF - GDS(14) = CHAR(MOD(LONO/65536,256)) - GDS(15) = CHAR(MOD(LONO/ 256,256)) - GDS(16) = CHAR(MOD(LONO ,256)) - LONM = IGDS(9) - IF (LONM .LT. 0) THEN - LONM = -LONM - LONM = IOR(LONM,8388608) - ENDIF - GDS(18) = CHAR(MOD(LONM/65536,256)) - GDS(19) = CHAR(MOD(LONM/ 256,256)) - GDS(20) = CHAR(MOD(LONM ,256)) - GDS(21) = CHAR(MOD(IGDS(10)/65536,256)) - GDS(22) = CHAR(MOD(IGDS(10)/ 256,256)) - GDS(23) = CHAR(MOD(IGDS(10) ,256)) - GDS(24) = CHAR(MOD(IGDS(11)/65536,256)) - GDS(25) = CHAR(MOD(IGDS(11)/ 256,256)) - GDS(26) = CHAR(MOD(IGDS(11) ,256)) - GDS(27) = CHAR(IGDS(12)) - GDS(28) = CHAR(IGDS(13)) - GDS(29) = CHAR(MOD(IGDS(15)/65536,256)) - GDS(30) = CHAR(MOD(IGDS(15)/ 256,256)) - GDS(31) = CHAR(MOD(IGDS(15) ,256)) - GDS(32) = CHAR(MOD(IGDS(16)/65536,256)) - GDS(33) = CHAR(MOD(IGDS(16)/ 256,256)) - GDS(34) = CHAR(MOD(IGDS(16) ,256)) - GDS(35) = CHAR(MOD(IGDS(17)/65536,256)) - GDS(36) = CHAR(MOD(IGDS(17)/ 256,256)) - GDS(37) = CHAR(MOD(IGDS(17) ,256)) - GDS(38) = CHAR(MOD(IGDS(18)/65536,256)) - GDS(39) = CHAR(MOD(IGDS(18)/ 256,256)) - GDS(40) = CHAR(MOD(IGDS(18) ,256)) - GDS(41) = CHAR(0) - GDS(42) = CHAR(0) -C$$ PROCESS POLAR STEREOGRAPHIC GRID TYPES - ELSE IF (IGDS(3) .EQ. 5) THEN - GDS( 7) = CHAR(MOD(IGDS(4)/256,256)) - GDS( 8) = CHAR(MOD(IGDS(4) ,256)) - GDS( 9) = CHAR(MOD(IGDS(5)/256,256)) - GDS(10) = CHAR(MOD(IGDS(5) ,256)) - LATO = IGDS(6) - IF (LATO .LT. 0) THEN - LATO = -LATO - LATO = IOR(LATO,8388608) - ENDIF - GDS(11) = CHAR(MOD(LATO/65536,256)) - GDS(12) = CHAR(MOD(LATO/ 256,256)) - GDS(13) = CHAR(MOD(LATO ,256)) - LONO = IGDS(7) - IF (LONO .LT. 0) THEN - LONO = -LONO - LONO = IOR(LONO,8388608) - ENDIF - GDS(14) = CHAR(MOD(LONO/65536,256)) - GDS(15) = CHAR(MOD(LONO/ 256,256)) - GDS(16) = CHAR(MOD(LONO ,256)) - LONM = IGDS(9) - IF (LONM .LT. 0) THEN - LONM = -LONM - LONM = IOR(LONM,8388608) - ENDIF - GDS(18) = CHAR(MOD(LONM/65536,256)) - GDS(19) = CHAR(MOD(LONM/ 256,256)) - GDS(20) = CHAR(MOD(LONM ,256)) - GDS(21) = CHAR(MOD(IGDS(10)/65536,256)) - GDS(22) = CHAR(MOD(IGDS(10)/ 256,256)) - GDS(23) = CHAR(MOD(IGDS(10) ,256)) - GDS(24) = CHAR(MOD(IGDS(11)/65536,256)) - GDS(25) = CHAR(MOD(IGDS(11)/ 256,256)) - GDS(26) = CHAR(MOD(IGDS(11) ,256)) - GDS(27) = CHAR(IGDS(12)) - GDS(28) = CHAR(IGDS(13)) - GDS(29) = CHAR(0) - GDS(30) = CHAR(0) - GDS(31) = CHAR(0) - GDS(32) = CHAR(0) - ENDIF -C PRINT 10,(GDS(IG),IG=1,32) -C10 FORMAT (' GDS= ',32(1X,Z2.2)) -C -C COMPUTE NUMBER OF POINTS IN GRID BY MULTIPLYING -C IGDS(4) AND IGDS(5) ... NEEDED FOR PACKER -C - IF (IGDS(3).EQ.0.AND.IGDS(1).EQ.0.AND.IGDS(2).NE. - & 255) THEN - NPTS = ISUM - ELSE - NPTS = IGDS(4) * IGDS(5) - ENDIF -C -C 'IOR' ICOMP-BIT 5 RESOLUTION & COMPONENT FLAG FOR WINDS -C WITH IGDS(8) INFO (REST OF RESOLUTION & COMPONENT FLAG DATA) -C - ITEMP = ISHFT(ICOMP,3) - GDS(17) = CHAR(IOR(IGDS(8),ITEMP)) -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi75.f b/external/w3nco/v2.0.6/src/w3fi75.f deleted file mode 100644 index bb5b2732e..000000000 --- a/external/w3nco/v2.0.6/src/w3fi75.f +++ /dev/null @@ -1,1619 +0,0 @@ - SUBROUTINE W3FI75 (IBITL,ITYPE,ITOSS,FLD,IFLD,IBMAP,IBDSFL, - & NPTS,BDS11,IPFLD,PFLD,LEN,LENBDS,IBERR,PDS,IGDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI75 GRIB PACK DATA AND FORM BDS OCTETS(1-11) -C PRGMMR: FARLEY ORG: NMC421 DATE:94-11-22 -C -C ABSTRACT: THIS ROUTINE PACKS A GRIB FIELD AND FORMS OCTETS(1-11) -C OF THE BINARY DATA SECTION (BDS). -C -C PROGRAM HISTORY LOG: -C 92-07-10 M. FARLEY ORIGINAL AUTHOR -C 92-10-01 R.E.JONES CORRECTION FOR FIELD OF CONSTANT DATA -C 92-10-16 R.E.JONES GET RID OF ARRAYS FP AND INT -C 93-08-06 CAVANAUGH ADDED ROUTINES FI7501, FI7502, FI7503 -C TO ALLOW SECOND ORDER PACKING IN PDS. -C 93-07-21 STACKPOLE ASSORTED REPAIRS TO GET 2ND DIFF PACK IN -C 93-10-28 CAVANAUGH COMMENTED OUT NONOPERATIONAL PRINTS AND -C WRITE STATEMENTS -C 93-12-15 CAVANAUGH CORRECTED LOCATION OF START OF FIRST ORDER -C VALUES AND START OF SECOND ORDER VALUES TO -C REFLECT A BYTE LOCATION IN THE BDS INSTEAD -C OF AN OFFSET IN SUBROUTINE FI7501. -C 94-01-27 CAVANAUGH ADDED IGDS AS INPUT ARGUMENT TO THIS ROUTINE -C AND ADDED PDS AND IGDS ARRAYS TO THE CALL TO -C W3FI82 TO PROVIDE INFORMATION NEEDED FOR -C BOUSTROPHEDONIC PROCESSING. -C 94-05-25 CAVANAUGH SUBROUTINE FI7503 HAS BEEN ADDED TO PROVIDE -C FOR ROW BY ROW OR COLUMN BY COLUMN SECOND -C ORDER PACKING. THIS FEATURE CAN BE ACTIVATED -C BY SETTING IBDSFL(7) TO ZERO. -C 94-07-08 CAVANAUGH COMMENTED OUT PRINT STATEMENTS USED FOR DEBUG -C 94-11-22 FARLEY ENLARGED WORK ARRAYS TO HANDLE .5DEGREE GRIDS -C 95-06-01 R.E.JONES CORRECTION FOR NUMBER OF UNUSED BITS AT END -C OF SECTION 4, IN BDS BYTE 4, BITS 5-8. -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 2001-06-06 GILBERT CHanged gbyte/sbyte calls to refer to -C Wesley Ebisuzaki's endian independent -C versions gbytec/sbytec. -C Use f90 standard routine bit_size to get -C number of bits in an integer instead of w3fi01. -C -C USAGE: CALL W3FI75 (IBITL,ITYPE,ITOSS,FLD,IFLD,IBMAP,IBDSFL, -C & NPTS,BDS11,IPFLD,PFLD,LEN,LENBDS,IBERR,PDS,IGDS) -C INPUT ARGUMENT LIST: -C IBITL - 0, COMPUTER COMPUTES PACKING LENGTH FROM POWER -C OF 2 THAT BEST FITS THE DATA. -C 8, 12, ETC. COMPUTER RESCALES DATA TO FIT INTO -C SET NUMBER OF BITS. -C ITYPE - 0 = IF INPUT DATA IS FLOATING POINT (FLD) -C 1 = IF INPUT DATA IS INTEGER (IFLD) -C ITOSS - 0 = NO BIT MAP IS INCLUDED (DON'T TOSS DATA) -C 1 = TOSS NULL DATA ACCORDING TO IBMAP -C FLD - REAL ARRAY OF DATA TO BE PACKED IF ITYPE=0 -C IFLD - INTEGER ARRAY TO BE PACKED IF ITYPE=1 -C IBMAP - BIT MAP SUPPLIED FROM USER -C IBDSFL - INTEGER ARRAY CONTAINING TABLE 11 FLAG INFO -C BDS OCTET 4: -C (1) 0 = GRID POINT DATA -C 1 = SPHERICAL HARMONIC COEFFICIENTS -C (2) 0 = SIMPLE PACKING -C 1 = SECOND ORDER PACKING -C (3) 0 = ORIGINAL DATA WERE FLOATING POINT VALUES -C 1 = ORIGINAL DATA WERE INTEGER VALUES -C (4) 0 = NO ADDITIONAL FLAGS AT OCTET 14 -C 1 = OCTET 14 CONTAINS FLAG BITS 5-12 -C (5) 0 = RESERVED - ALWAYS SET TO 0 -C (6) 0 = SINGLE DATUM AT EACH GRID POINT -C 1 = MATRIX OF VALUES AT EACH GRID POINT -C (7) 0 = NO SECONDARY BIT MAPS -C 1 = SECONDARY BIT MAPS PRESENT -C (8) 0 = SECOND ORDER VALUES HAVE CONSTANT WIDTH -C 1 = SECOND ORDER VALUES HAVE DIFFERENT WIDTHS -C NPTS - NUMBER OF GRIDPOINTS IN ARRAY TO BE PACKED -C IGDS - ARRAY OF GDS INFORMATION -C -C OUTPUT ARGUMENT LIST: -C BDS11 - FIRST 11 OCTETS OF BDS -C PFLD - PACKED GRIB FIELD -C LEN - LENGTH OF PFLD -C LENBDS - LENGTH OF BDS -C IBERR - 1, ERROR CONVERTING IEEE F.P. NUMBER TO IBM370 F.P. -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ -C - REAL FLD(*) -C REAL FWORK(260000) -C -C FWORK CAN USE DYNAMIC ALLOCATION OF MEMORY ON CRAY -C - REAL FWORK(NPTS) - REAL RMIN,REFNCE -C - character(len=1) IPFLD(*) - INTEGER IBDSFL(*) - INTEGER IBMAP(*) - INTEGER IFLD(*),IGDS(*) -C INTEGER IWORK(260000) -C -C IWORK CAN USE DYNAMIC ALLOCATION OF MEMORY ON CRAY -C - INTEGER IWORK(NPTS) -C - LOGICAL CONST -C - CHARACTER * 1 BDS11(11),PDS(*) - CHARACTER * 1 PFLD(*) -C -C 1.0 PACK THE FIELD. -C -C 1.1 TOSS DATA IF BITMAP BEING USED, -C MOVING 'DATA' TO WORK AREA... -C - CONST = .FALSE. - IBERR = 0 - IW = 0 -C - IF (ITOSS .EQ. 1) THEN - IF (ITYPE .EQ. 0) THEN - DO 110 IT=1,NPTS - IF (IBMAP(IT) .EQ. 1) THEN - IW = IW + 1 - FWORK(IW) = FLD(IT) - ENDIF - 110 CONTINUE - NPTS = IW - ELSE IF (ITYPE .EQ. 1) THEN - DO 111 IT=1,NPTS - IF (IBMAP(IT) .EQ. 1) THEN - IW = IW + 1 - IWORK(IW) = IFLD(IT) - ENDIF - 111 CONTINUE - NPTS = IW - ENDIF -C -C ELSE, JUST MOVE DATA TO WORK ARRAY -C - ELSE IF (ITOSS .EQ. 0) THEN - IF (ITYPE .EQ. 0) THEN - DO 112 IT=1,NPTS - FWORK(IT) = FLD(IT) - 112 CONTINUE - ELSE IF (ITYPE .EQ. 1) THEN - DO 113 IT=1,NPTS - IWORK(IT) = IFLD(IT) - 113 CONTINUE - ENDIF - ENDIF -C -C 1.2 CONVERT DATA IF NEEDED PRIOR TO PACKING. -C (INTEGER TO F.P. OR F.P. TO INTEGER) -C ITYPE = 0...FLOATING POINT DATA -C IBITL = 0...PACK IN LEAST # BITS...CONVERT TO INTEGER -C ITYPE = 1...INTEGER DATA -C IBITL > 0...PACK IN FIXED # BITS...CONVERT TO FLOATING POINT -C - IF (ITYPE .EQ. 0 .AND. IBITL .EQ. 0) THEN - DO 120 IF=1,NPTS - IWORK(IF) = NINT(FWORK(IF)) - 120 CONTINUE - ELSE IF (ITYPE .EQ. 1 .AND. IBITL .NE. 0) THEN - DO 123 IF=1,NPTS - FWORK(IF) = FLOAT(IWORK(IF)) - 123 CONTINUE - ENDIF -C -C 1.3 PACK THE DATA. -C - IF (IBDSFL(2).NE.0) THEN -C SECOND ORDER PACKING -C -C PRINT*,' DOING SECOND ORDER PACKING...' - IF (IBITL.EQ.0) THEN -C -C PRINT*,' AND VARIABLE BIT PACKING' -C -C WORKING WITH INTEGER VALUES -C SINCE DOING VARIABLE BIT PACKING -C - MAX = IWORK(1) - MIN = IWORK(1) - DO 300 I = 2, NPTS - IF (IWORK(I).LT.MIN) THEN - MIN = IWORK(I) - ELSE IF (IWORK(I).GT.MAX) THEN - MAX = IWORK(I) - END IF - 300 CONTINUE -C EXTRACT MINIMA - DO 400 I = 1, NPTS -C IF (IWORK(I).LT.0) THEN -C PRINT *,'MINIMA 400',I,IWORK(I),NPTS -C END IF - IWORK(I) = IWORK(I) - MIN - 400 CONTINUE - REFNCE = MIN - IDIFF = MAX - MIN -C PRINT *,'REFERENCE VALUE',REFNCE -C -C WRITE (6,FMT='('' MINIMA REMOVED = '',/, -C & 10(3X,10I10,/))') (IWORK(I),I=1,6) -C WRITE (6,FMT='('' END OF ARRAY = '',/, -C & 10(3X,10I10,/))') (IWORK(I),I=NPTS-5,NPTS) -C -C FIND BIT WIDTH OF IDIFF -C - CALL FI7505 (IDIFF,KWIDE) -C PRINT*,' BIT WIDTH FOR ORIGINAL DATA', KWIDE - ISCAL2 = 0 -C -C MULTIPLICATIVE SCALE FACTOR SET TO 1 -C IN ANTICIPATION OF POSSIBLE USE IN GLAHN 2DN DIFF -C - SCAL2 = 1. -C - ELSE -C -C PRINT*,' AND FIXED BIT PACKING, IBITL = ', IBITL -C FIXED BIT PACKING -C - LENGTH OF FIELD IN IBITL -C - MUST BE REAL DATA -C FLOATING POINT INPUT -C - RMAX = FWORK(1) - RMIN = FWORK(1) - DO 100 I = 2, NPTS - IF (FWORK(I).LT.RMIN) THEN - RMIN = FWORK(I) - ELSE IF (FWORK(I).GT.RMAX) THEN - RMAX = FWORK(I) - END IF - 100 CONTINUE - REFNCE = RMIN -C PRINT *,'100 REFERENCE',REFNCE -C EXTRACT MINIMA - DO 200 I = 1, NPTS - FWORK(I) = FWORK(I) - RMIN - 200 CONTINUE -C PRINT *,'REFERENCE VALUE',REFNCE -C WRITE (6,FMT='('' MINIMA REMOVED = '',/, -C & 10(3X,10F8.2,/))') (FWORK(I),I=1,6) -C WRITE (6,FMT='('' END OF ARRAY = '',/, -C & 10(3X,10F8.2,/))') (FWORK(I),I=NPTS-5,NPTS) -C FIND LARGEST DELTA - IDELT = NINT(RMAX - RMIN) -C DO BINARY SCALING -C FIND OUT WHAT BINARY SCALE FACTOR -C PERMITS CONTAINMENT OF -C LARGEST DELTA - CALL FI7505 (IDELT,IWIDE) -C -C BINARY SCALING -C - ISCAL2 = IWIDE - IBITL -C PRINT *,'SCALING NEEDED TO FIT =',ISCAL2 -C PRINT*,' RANGE OF = ',IDELT -C -C EXPAND DATA WITH BINARY SCALING -C CONVERT TO INTEGER - SCAL2 = 2.0**ISCAL2 - SCAL2 = 1./ SCAL2 - DO 600 I = 1, NPTS - IWORK(I) = NINT(FWORK(I) * SCAL2) - 600 CONTINUE - KWIDE = IBITL - END IF -C -C ***************************************************************** -C -C FOLLOWING IS FOR GLAHN SECOND DIFFERENCING -C NOT STANDARD GRIB -C -C TEST FOR SECOND DIFFERENCE PACKING -C BASED OF SIZE OF PDS - SIZE IN FIRST 3 BYTES -C - CALL GBYTEC(PDS,IPDSIZ,0,24) - IF (IPDSIZ.EQ.50) THEN -C PRINT*,' DO SECOND DIFFERENCE PACKING ' -C -C GLAHN PACKING TO 2ND DIFFS -C -C WRITE (6,FMT='('' CALL TO W3FI82 WITH = '',/, -C & 10(3X,10I6,/))') (IWORK(I),I=1,NPTS) -C - CALL W3FI82 (IWORK,FVAL1,FDIFF1,NPTS,PDS,IGDS) -C -C PRINT *,'GLAHN',FVAL1,FDIFF1 -C WRITE (6,FMT='('' OUT FROM W3FI82 WITH = '',/, -C & 10(3X,10I6,/))') (IWORK(I),I=1,NPTS) -C -C MUST NOW RE-REMOVE THE MINIMUM VALUE -C OF THE SECOND DIFFERENCES TO ASSURE -C ALL POSITIVE NUMBERS FOR SECOND ORDER GRIB PACKING -C -C ORIGINAL REFERENCE VALUE ADDED TO FIRST POINT -C VALUE FROM THE 2ND DIFF PACKER TO BE ADDED -C BACK IN WHEN THE 2ND DIFF VALUES ARE -C RECONSTRUCTED BACK TO THE BASIC VALUES -C -C ALSO, THE REFERENCE VALUE IS -C POWER-OF-TWO SCALED TO MATCH -C FVAL1. ALL OF THIS SCALING -C WILL BE REMOVED AFTER THE -C GLAHN SECOND DIFFERENCING IS UNDONE. -C THE SCALING FACTOR NEEDED TO DO THAT -C IS SAVED IN THE PDS AS A SIGNED POSITIVE -C TWO BYTE INTEGER -C -C THE SCALING FOR THE 2ND DIF PACKED -C VALUES IS PROPERLY SET TO ZERO -C - FVAL1 = FVAL1 + REFNCE*SCAL2 -C FIRST TEST TO SEE IF -C ON 32 OR 64 BIT COMPUTER -C CALL W3FI01(LW) - IF (bit_size(LW).EQ.32) THEN - CALL W3FI76 (FVAL1,IEXP,IMANT,32) - ELSE - CALL W3FI76 (FVAL1,IEXP,IMANT,64) - END IF - CALL SBYTEC(PDS,IEXP,320,8) - CALL SBYTEC(PDS,IMANT,328,24) -C - IF (bit_size(LW).EQ.32) THEN - CALL W3FI76 (FDIFF1,IEXP,IMANT,32) - ELSE - CALL W3FI76 (FDIFF1,IEXP,IMANT,64) - END IF - CALL SBYTEC(PDS,IEXP,352,8) - CALL SBYTEC(PDS,IMANT,360,24) -C -C TURN ISCAL2 INTO SIGNED POSITIVE INTEGER -C AND STORE IN TWO BYTES -C - IF(ISCAL2.GE.0) THEN - CALL SBYTEC(PDS,ISCAL2,384,16) - ELSE - CALL SBYTEC(PDS,1,384,1) - ISCAL2 = - ISCAL2 - CALL SBYTEC( PDS,ISCAL2,385,15) - ENDIF -C - MAX = IWORK(1) - MIN = IWORK(1) - DO 700 I = 2, NPTS - IF (IWORK(I).LT.MIN) THEN - MIN = IWORK(I) - ELSE IF (IWORK(I).GT.MAX) THEN - MAX = IWORK(I) - END IF - 700 CONTINUE -C EXTRACT MINIMA - DO 710 I = 1, NPTS - IWORK(I) = IWORK(I) - MIN - 710 CONTINUE - REFNCE = MIN -C PRINT *,'710 REFERENCE',REFNCE - ISCAL2 = 0 -C -C AND RESET VALUE OF KWIDE - THE BIT WIDTH -C FOR THE RANGE OF THE VALUES -C - IDIFF = MAX - MIN - CALL FI7505 (IDIFF,KWIDE) -C -C PRINT*,'BIT WIDTH (KWIDE) OF 2ND DIFFS', KWIDE -C -C **************************** END OF GLAHN PACKING ************ - ELSE IF (IBDSFL(2).EQ.1.AND.IBDSFL(7).EQ.0) THEN -C HAVE SECOND ORDER PACKING WITH NO SECOND ORDER -C BIT MAP. ERGO ROW BY ROW - COL BY COL - CALL FI7503 (IWORK,IPFLD,NPTS,IBDSFL,BDS11, - * LEN,LENBDS,PDS,REFNCE,ISCAL2,KWIDE,IGDS) - RETURN - END IF -C WRITE (6,FMT='('' CALL TO FI7501 WITH = '',/, -C & 10(3X,10I6,/))') (IWORK(I),I=1,NPTS) -C WRITE (6,FMT='('' END OF ARRAY = '',/, -C & 10(3X,10I6,/))') (IWORK(I),I=NPTS-5,NPTS) -C PRINT*,' REFNCE,ISCAL2, KWIDE AT CALL TO FI7501', -C & REFNCE, ISCAL2,KWIDE -C -C SECOND ORDER PACKING -C - CALL FI7501 (IWORK,IPFLD,NPTS,IBDSFL,BDS11, - * LEN,LENBDS,PDS,REFNCE,ISCAL2,KWIDE) -C -C BDS COMPLETELY ASSEMBLED IN FI7501 FOR SECOND ORDER -C PACKING. -C - ELSE -C SIMPLE PACKING -C -C PRINT*,' SIMPLE FIRST ORDER PACKING...' - IF (IBITL.EQ.0) THEN -C PRINT*,' WITH VARIABLE BIT LENGTH' -C -C WITH VARIABLE BIT LENGTH, ADJUSTED -C TO ACCOMMODATE LARGEST VALUE -C BINARY SCALING ALWAYS = 0 -C - CALL W3FI58(IWORK,NPTS,IWORK,PFLD,NBITS,LEN,KMIN) - RMIN = KMIN - REFNCE = RMIN - ISCALE = 0 -C PRINT*,' BIT LENGTH CAME OUT AT ...',NBITS -C -C SET CONST .TRUE. IF ALL VALUES ARE THE SAME -C - IF (LEN.EQ.0.AND.NBITS.EQ.0) CONST = .TRUE. -C - ELSE -C PRINT*,' FIXED BIT LENGTH, IBITL = ', IBITL -C -C FIXED BIT LENGTH PACKING (VARIABLE PRECISION) -C VALUES SCALED BY POWER OF 2 (ISCALE) TO -C FIT LARGEST VALUE INTO GIVEN BIT LENGTH (IBITL) -C - CALL W3FI59(FWORK,NPTS,IBITL,IWORK,PFLD,ISCALE,LEN,RMIN) - REFNCE = RMIN -C PRINT *,' SCALING NEEDED TO FIT IS ...', ISCALE - NBITS = IBITL -C -C SET CONST .TRUE. IF ALL VALUES ARE THE SAME -C - IF (LEN.EQ.0) THEN - CONST = .TRUE. - NBITS = 0 - END IF - END IF -C -C COMPUTE LENGTH OF BDS IN OCTETS -C - INUM = NPTS * NBITS + 88 -C PRINT *,'NUMBER OF BITS BEFORE FILL ADDED',INUM -C -C NUMBER OF FILL BITS - NFILL = 0 - NLEFT = MOD(INUM,16) - IF (NLEFT.NE.0) THEN - INUM = INUM + 16 - NLEFT - NFILL = 16 - NLEFT - END IF -C PRINT *,'NUMBER OF BITS AFTER FILL ADDED',INUM -C LENGTH OF BDS IN BYTES - LENBDS = INUM / 8 -C -C 2.0 FORM THE BINARY DATA SECTION (BDS). -C -C CONCANTENATE ALL FIELDS FOR BDS -C -C BYTES 1-3 - CALL SBYTEC (BDS11,LENBDS,0,24) -C -C BYTE 4 -C FLAGS - CALL SBYTEC (BDS11,IBDSFL(1),24,1) - CALL SBYTEC (BDS11,IBDSFL(2),25,1) - CALL SBYTEC (BDS11,IBDSFL(3),26,1) - CALL SBYTEC (BDS11,IBDSFL(4),27,1) -C NR OF FILL BITS - CALL SBYTEC (BDS11,NFILL,28,4) -C -C FILL OCTETS 5-6 WITH THE SCALE FACTOR. -C -C BYTE 5-6 - IF (ISCALE.LT.0) THEN - CALL SBYTEC (BDS11,1,32,1) - ISCALE = - ISCALE - CALL SBYTEC (BDS11,ISCALE,33,15) - ELSE - CALL SBYTEC (BDS11,ISCALE,32,16) - END IF -C -C FILL OCTET 7-10 WITH THE REFERENCE VALUE -C CONVERT THE FLOATING POINT OF YOUR MACHINE TO IBM370 32 BIT -C FLOATING POINT NUMBER -C -C BYTE 7-10 -C REFERENCE VALUE -C FIRST TEST TO SEE IF -C ON 32 OR 64 BIT COMPUTER -C CALL W3FI01(LW) - IF (bit_size(LW).EQ.32) THEN - CALL W3FI76 (REFNCE,IEXP,IMANT,32) - ELSE - CALL W3FI76 (REFNCE,IEXP,IMANT,64) - END IF - CALL SBYTEC (BDS11,IEXP,48,8) - CALL SBYTEC (BDS11,IMANT,56,24) -C -C -C FILL OCTET 11 WITH THE NUMBER OF BITS. -C -C BYTE 11 - CALL SBYTEC (BDS11,NBITS,80,8) - END IF -C - RETURN - END - SUBROUTINE FI7501 (IWORK,IPFLD,NPTS,IBDSFL,BDS11, - * LEN,LENBDS,PDS,REFNCE,ISCAL2,KWIDE) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI7501 BDS SECOND ORDER PACKING -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 93-08-06 -C -C ABSTRACT: PERFORM SECONDARY PACKING ON GRID POINT DATA, -C GENERATING ALL BDS INFORMATION. -C -C PROGRAM HISTORY LOG: -C 93-08-06 CAVANAUGH -C 93-12-15 CAVANAUGH CORRECTED LOCATION OF START OF FIRST ORDER -C VALUES AND START OF SECOND ORDER VALUES TO -C REFLECT A BYTE LOCATION IN THE BDS INSTEAD -C OF AN OFFSET. -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL FI7501 (IWORK,IPFLD,NPTS,IBDSFL,BDS11, -C * LEN,LENBDS,PDS,REFNCE,ISCAL2,KWIDE) -C INPUT ARGUMENT LIST: -C IWORK - INTEGER SOURCE ARRAY -C NPTS - NUMBER OF POINTS IN IWORK -C IBDSFL - FLAGS -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IPFLD - CONTAINS BDS FROM BYTE 12 ON -C BDS11 - CONTAINS FIRST 11 BYTES FOR BDS -C LEN - NUMBER OF BYTES FROM 12 ON -C LENBDS - TOTAL LENGTH OF BDS -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ - CHARACTER*1 BDS11(*),PDS(*) -C - REAL REFNCE -C - INTEGER ISCAL2,KWIDE - INTEGER LENBDS - CHARACTER(len=1) IPFLD(*) - INTEGER LEN,KBDS(22) - INTEGER IWORK(*) -C OCTET NUMBER IN SECTION, FIRST ORDER PACKING -C INTEGER KBDS(12) -C FLAGS - INTEGER IBDSFL(*) -C EXTENDED FLAGS -C INTEGER KBDS(14) -C OCTET NUMBER FOR SECOND ORDER PACKING -C INTEGER KBDS(15) -C NUMBER OF FIRST ORDER VALUES -C INTEGER KBDS(17) -C NUMBER OF SECOND ORDER PACKED VALUES -C INTEGER KBDS(19) -C WIDTH OF SECOND ORDER PACKING - character(len=1) ISOWID(400000) -C SECONDARY BIT MAP - character(len=1) ISOBMP(65600) -C FIRST ORDER PACKED VALUES - character(len=1) IFOVAL(400000) -C SECOND ORDER PACKED VALUES - character(len=1) ISOVAL(800000) -C -C INTEGER KBDS(11) -C BIT WIDTH TABLE - INTEGER IBITS(31) -C - DATA IBITS/1,3,7,15,31,63,127,255,511,1023, - * 2047,4095,8191,16383,32767,65535,131072, - * 262143,524287,1048575,2097151,4194303, - * 8388607,16777215,33554431,67108863, - * 134217727,268435455,536870911, - * 1073741823,2147483647/ -C ---------------------------------- -C INITIALIZE ARRAYS - - DO I = 1, 400000 - IFOVAL(I) = char(0) - ISOWID(I) = char(0) - ENDDO -C - DO 101 I = 1, 65600 - ISOBMP(I) = char(0) - 101 CONTINUE - DO 102 I = 1, 800000 - ISOVAL(I) = char(0) - 102 CONTINUE -C INITIALIZE POINTERS -C SECONDARY BIT WIDTH POINTER - IWDPTR = 0 -C SECONDARY BIT MAP POINTER - IBMP2P = 0 -C FIRST ORDER VALUE POINTER - IFOPTR = 0 -C BYTE POINTER TO START OF 1ST ORDER VALUES - KBDS(12) = 0 -C BYTE POINTER TO START OF 2ND ORDER VALUES - KBDS(15) = 0 -C TO CONTAIN NUMBER OF FIRST ORDER VALUES - KBDS(17) = 0 -C TO CONTAIN NUMBER OF SECOND ORDER VALUES - KBDS(19) = 0 -C SECOND ORDER PACKED VALUE POINTER - ISOPTR = 0 -C ======================================================= -C -C DATA IS IN IWORK -C - KBDS(11) = KWIDE -C -C DATA PACKING -C - ITER = 0 - INEXT = 1 - ISTART = 1 -C ----------------------------------------------------------- - KOUNT = 0 -C DO 1 I = 1, NPTS, 10 -C PRINT *,I,(IWORK(K),K=I, I+9) -C 1 CONTINUE - 2000 CONTINUE - ITER = ITER + 1 -C PRINT *,'NEXT ITERATION STARTS AT',ISTART - IF (ISTART.GT.NPTS) THEN - GO TO 4000 - ELSE IF (ISTART.EQ.NPTS) THEN - KPTS = 1 - MXDIFF = 0 - GO TO 2200 - END IF -C -C LOOK FOR REPITITIONS OF A SINGLE VALUE - CALL FI7502 (IWORK,ISTART,NPTS,ISAME) - IF (ISAME.GE.15) THEN - KOUNT = KOUNT + 1 -C PRINT *,'FI7501 - FOUND IDENTICAL SET OF ',ISAME - MXDIFF = 0 - KPTS = ISAME - ELSE -C -C LOOK FOR SETS OF VALUES IN TREND SELECTED RANGE - CALL FI7513 (IWORK,ISTART,NPTS,NMAX,NMIN,INRNGE) -C PRINT *,'ISTART ',ISTART,' INRNGE',INRNGE,NMAX,NMIN - IEND = ISTART + INRNGE - 1 -C DO 2199 NM = ISTART, IEND, 10 -C PRINT *,' ',(IWORK(NM+JK),JK=0,9) -C2199 CONTINUE - MXDIFF = NMAX - NMIN - KPTS = INRNGE - END IF - 2200 CONTINUE -C PRINT *,' RANGE ',MXDIFF,' MAX',NMAX,' MIN',NMIN -C INCREMENT NUMBER OF FIRST ORDER VALUES - KBDS(17) = KBDS(17) + 1 -C ENTER FIRST ORDER VALUE - IF (MXDIFF.GT.0) THEN - DO 2220 LK = 0, KPTS-1 - IWORK(ISTART+LK) = IWORK(ISTART+LK) - NMIN - 2220 CONTINUE - CALL SBYTEC (IFOVAL,NMIN,IFOPTR,KBDS(11)) - ELSE - CALL SBYTEC (IFOVAL,IWORK(ISTART),IFOPTR,KBDS(11)) - END IF - IFOPTR = IFOPTR + KBDS(11) -C PROCESS SECOND ORDER BIT WIDTH - IF (MXDIFF.GT.0) THEN - DO 2330 KWIDE = 1, 31 - IF (MXDIFF.LE.IBITS(KWIDE)) THEN - GO TO 2331 - END IF - 2330 CONTINUE - 2331 CONTINUE - ELSE - KWIDE = 0 - END IF - CALL SBYTEC (ISOWID,KWIDE,IWDPTR,8) - IWDPTR = IWDPTR + 8 -C PRINT *,KWIDE,' IFOVAL=',NMIN,IWORK(ISTART),KPTS -C IF KWIDE NE 0, SAVE SECOND ORDER VALUE - IF (KWIDE.GT.0) THEN - CALL SBYTESC (ISOVAL,IWORK(ISTART),ISOPTR,KWIDE,0,KPTS) - ISOPTR = ISOPTR + KPTS * KWIDE - KBDS(19) = KBDS(19) + KPTS -C PRINT *,' SECOND ORDER VALUES' -C PRINT *,(IWORK(ISTART+I),I=0,KPTS-1) - END IF -C ADD TO SECOND ORDER BITMAP - CALL SBYTEC (ISOBMP,1,IBMP2P,1) - IBMP2P = IBMP2P + KPTS - ISTART = ISTART + KPTS - GO TO 2000 -C -------------------------------------------------------------- - 4000 CONTINUE -C PRINT *,'THERE WERE ',ITER,' SECOND ORDER GROUPS' -C PRINT *,'THERE WERE ',KOUNT,' STRINGS OF CONSTANTS' -C CONCANTENATE ALL FIELDS FOR BDS -C -C REMAINDER GOES INTO IPFLD - IPTR = 0 -C BYTES 12-13 -C VALUE FOR N1 -C LEAVE SPACE FOR THIS - IPTR = IPTR + 16 -C BYTE 14 -C EXTENDED FLAGS - CALL SBYTEC (IPFLD,IBDSFL(5),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(6),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(7),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(8),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(9),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(10),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(11),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(12),IPTR,1) - IPTR = IPTR + 1 -C BYTES 15-16 -C SKIP OVER VALUE FOR N2 - IPTR = IPTR + 16 -C BYTES 17-18 -C P1 - CALL SBYTEC (IPFLD,KBDS(17),IPTR,16) - IPTR = IPTR + 16 -C BYTES 19-20 -C P2 - CALL SBYTEC (IPFLD,KBDS(19),IPTR,16) - IPTR = IPTR + 16 -C BYTE 21 - RESERVED LOCATION - CALL SBYTEC (IPFLD,0,IPTR,8) - IPTR = IPTR + 8 -C BYTES 22 - ? -C WIDTHS OF SECOND ORDER PACKING - IX = (IWDPTR + 32) / 32 -C CALL SBYTESC (IPFLD,ISOWID,IPTR,32,0,IX) - ijk=IWDPTR/8 - jst=(iptr/8)+1 - ipfld(jst:jst+ijk)=ISOWID(1:ijk) - IPTR = IPTR + IWDPTR -C SECONDARY BIT MAP - IJ = (IBMP2P + 32) / 32 -C CALL SBYTESC (IPFLD,ISOBMP,IPTR,32,0,IJ) - ijk=(IBMP2P/8)+1 - jst=(iptr/8)+1 - ipfld(jst:jst+ijk)=ISOBMP(1:ijk) - IPTR = IPTR + IBMP2P - IF (MOD(IPTR,8).NE.0) THEN - IPTR = IPTR + 8 - MOD(IPTR,8) - END IF -C DETERMINE LOCATION FOR START -C OF FIRST ORDER PACKED VALUES - KBDS(12) = IPTR / 8 + 12 -C STORE LOCATION - CALL SBYTEC (IPFLD,KBDS(12),0,16) -C MOVE IN FIRST ORDER PACKED VALUES - IPASS = (IFOPTR + 32) / 32 -C CALL SBYTESC (IPFLD,IFOVAL,IPTR,32,0,IPASS) - ijk=(IFOPTR/8)+1 - jst=(iptr/8)+1 - ipfld(jst:jst+ijk)=ifoval(1:ijk) - IPTR = IPTR + IFOPTR - IF (MOD(IPTR,8).NE.0) THEN - IPTR = IPTR + 8 - MOD(IPTR,8) - END IF -C PRINT *,'IFOPTR =',IFOPTR,' ISOPTR =',ISOPTR -C DETERMINE LOCATION FOR START -C OF SECOND ORDER VALUES - KBDS(15) = IPTR / 8 + 12 -C SAVE LOCATION OF SECOND ORDER VALUES - CALL SBYTEC (IPFLD,KBDS(15),24,16) -C MOVE IN SECOND ORDER PACKED VALUES - IX = (ISOPTR + 32) / 32 -c CALL SBYTESC (IPFLD,ISOVAL,IPTR,32,0,IX) - ijk=(ISOPTR/8)+1 - jst=(iptr/8)+1 - ipfld(jst:jst+ijk)=isoval(1:ijk) - IPTR = IPTR + ISOPTR - NLEFT = MOD(IPTR+88,16) - IF (NLEFT.NE.0) THEN - NLEFT = 16 - NLEFT - IPTR = IPTR + NLEFT - END IF -C COMPUTE LENGTH OF DATA PORTION - LEN = IPTR / 8 -C COMPUTE LENGTH OF BDS - LENBDS = LEN + 11 -C ----------------------------------- -C BYTES 1-3 -C THIS FUNCTION COMPLETED BELOW -C WHEN LENGTH OF BDS IS KNOWN - CALL SBYTEC (BDS11,LENBDS,0,24) -C BYTE 4 - CALL SBYTEC (BDS11,IBDSFL(1),24,1) - CALL SBYTEC (BDS11,IBDSFL(2),25,1) - CALL SBYTEC (BDS11,IBDSFL(3),26,1) - CALL SBYTEC (BDS11,IBDSFL(4),27,1) -C ENTER NUMBER OF FILL BITS - CALL SBYTEC (BDS11,NLEFT,28,4) -C BYTE 5-6 - IF (ISCAL2.LT.0) THEN - CALL SBYTEC (BDS11,1,32,1) - ISCAL2 = - ISCAL2 - ELSE - CALL SBYTEC (BDS11,0,32,1) - END IF - CALL SBYTEC (BDS11,ISCAL2,33,15) -C -C FILL OCTET 7-10 WITH THE REFERENCE VALUE -C CONVERT THE FLOATING POINT OF YOUR MACHINE TO IBM370 32 BIT -C FLOATING POINT NUMBER -C REFERENCE VALUE -C FIRST TEST TO SEE IF -C ON 32 OR 64 BIT COMPUTER -C CALL W3FI01(LW) - IF (bit_size(LW).EQ.32) THEN - CALL W3FI76 (REFNCE,IEXP,IMANT,32) - ELSE - CALL W3FI76 (REFNCE,IEXP,IMANT,64) - END IF - CALL SBYTEC (BDS11,IEXP,48,8) - CALL SBYTEC (BDS11,IMANT,56,24) -C -C BYTE 11 -C - CALL SBYTEC (BDS11,KBDS(11),80,8) -C - RETURN - END - SUBROUTINE FI7502 (IWORK,ISTART,NPTS,ISAME) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI7502 SECOND ORDER SAME VALUE COLLECTION -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 93-06-23 -C -C ABSTRACT: COLLECT SEQUENTIAL SAME VALUES FOR PROCESSING -C AS SECOND ORDER VALUE FOR GRIB MESSAGES. -C -C PROGRAM HISTORY LOG: -C 93-06-23 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL FI7502 (IWORK,ISTART,NPTS,ISAME) -C INPUT ARGUMENT LIST: -C IWORK - ARRAY CONTAINING SOURCE DATA -C ISTART - STARTING LOCATION FOR THIS TEST -C NPTS - NUMBER OF POINTS IN IWORK -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C ISAME - NUMBER OF SEQUENTIAL POINTS HAVING THE SAME VALUE -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ - INTEGER IWORK(*) - INTEGER ISTART - INTEGER ISAME - INTEGER K - INTEGER NPTS -C ------------------------------------------------------------- - ISAME = 0 - DO 100 K = ISTART, NPTS - IF (IWORK(K).NE.IWORK(ISTART)) THEN - RETURN - END IF - ISAME = ISAME + 1 - 100 CONTINUE - RETURN - END - SUBROUTINE FI7503 (IWORK,IPFLD,NPTS,IBDSFL,BDS11, - * LEN,LENBDS,PDS,REFNCE,ISCAL2,KWIDE,IGDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI7501 ROW BY ROW, COL BY COL PACKING -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 94-05-20 -C -C ABSTRACT: PERFORM ROW BY ROW OR COLUMN BY COLUMN PACKING -C GENERATING ALL BDS INFORMATION. -C -C PROGRAM HISTORY LOG: -C 93-08-06 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL FI7503 (IWORK,IPFLD,NPTS,IBDSFL,BDS11, -C * LEN,LENBDS,PDS,REFNCE,ISCAL2,KWIDE,IGDS) -C INPUT ARGUMENT LIST: -C IWORK - INTEGER SOURCE ARRAY -C NPTS - NUMBER OF POINTS IN IWORK -C IBDSFL - FLAGS -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IPFLD - CONTAINS BDS FROM BYTE 12 ON -C BDS11 - CONTAINS FIRST 11 BYTES FOR BDS -C LEN - NUMBER OF BYTES FROM 12 ON -C LENBDS - TOTAL LENGTH OF BDS -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ - CHARACTER*1 BDS11(*),PDS(*),IPFLD(*) -C - REAL REFNCE -C - INTEGER ISCAL2,KWIDE - INTEGER LENBDS - INTEGER IGDS(*) - INTEGER LEN,KBDS(22) - INTEGER IWORK(*) -C OCTET NUMBER IN SECTION, FIRST ORDER PACKING -C INTEGER KBDS(12) -C FLAGS - INTEGER IBDSFL(*) -C EXTENDED FLAGS -C INTEGER KBDS(14) -C OCTET NUMBER FOR SECOND ORDER PACKING -C INTEGER KBDS(15) -C NUMBER OF FIRST ORDER VALUES -C INTEGER KBDS(17) -C NUMBER OF SECOND ORDER PACKED VALUES -C INTEGER KBDS(19) -C WIDTH OF SECOND ORDER PACKING - character(len=1) ISOWID(400000) -C SECONDARY BIT MAP - character(len=1) ISOBMP(65600) -C FIRST ORDER PACKED VALUES - character(len=1) IFOVAL(400000) -C SECOND ORDER PACKED VALUES - character(len=1) ISOVAL(800000) -C -C INTEGER KBDS(11) -C ---------------------------------- -C INITIALIZE ARRAYS -C - DO I = 1, 400000 - IFOVAL(I) = char(0) - ISOWID(I) = char(0) - ENDDO -C - DO 101 I = 1, 65600 - ISOBMP(I) = char(0) - 101 CONTINUE - DO 102 I = 1, 800000 - ISOVAL(I) = char(0) - 102 CONTINUE -C INITIALIZE POINTERS -C SECONDARY BIT WIDTH POINTER - IWDPTR = 0 -C SECONDARY BIT MAP POINTER - IBMP2P = 0 -C FIRST ORDER VALUE POINTER - IFOPTR = 0 -C BYTE POINTER TO START OF 1ST ORDER VALUES - KBDS(12) = 0 -C BYTE POINTER TO START OF 2ND ORDER VALUES - KBDS(15) = 0 -C TO CONTAIN NUMBER OF FIRST ORDER VALUES - KBDS(17) = 0 -C TO CONTAIN NUMBER OF SECOND ORDER VALUES - KBDS(19) = 0 -C SECOND ORDER PACKED VALUE POINTER - ISOPTR = 0 -C ======================================================= -C BUILD SECOND ORDER BIT MAP IN EITHER -C ROW BY ROW OR COL BY COL FORMAT - IF (IAND(IGDS(13),32).NE.0) THEN -C COLUMN BY COLUMN - KOUT = IGDS(4) - KIN = IGDS(5) -C PRINT *,'COLUMN BY COLUMN',KOUT,KIN - ELSE -C ROW BY ROW - KOUT = IGDS(5) - KIN = IGDS(4) -C PRINT *,'ROW BY ROW',KOUT,KIN - END IF - KBDS(17) = KOUT - KBDS(19) = NPTS -C -C DO 4100 J = 1, NPTS, 53 -C WRITE (6,4101) (IWORK(K),K=J,J+52) - 4101 FORMAT (1X,25I4) -C PRINT *,' ' -C4100 CONTINUE -C -C INITIALIZE BIT MAP POINTER - IBMP2P = 0 -C CONSTRUCT WORKING BIT MAP - DO 2000 I = 1, KOUT - DO 1000 J = 1, KIN - IF (J.EQ.1) THEN - CALL SBYTEC (ISOBMP,1,IBMP2P,1) - ELSE - CALL SBYTEC (ISOBMP,0,IBMP2P,1) - END IF - IBMP2P = IBMP2P + 1 - 1000 CONTINUE - 2000 CONTINUE - LEN = IBMP2P / 32 + 1 -C CALL BINARY(ISOBMP,LEN) -C -C PROCESS OUTER LOOP OF ROW BY ROW OR COL BY COL -C - KPTR = 1 - KBDS(11) = KWIDE - DO 6000 I = 1, KOUT -C IN CURRENT ROW OR COL -C FIND FIRST ORDER VALUE - JPTR = KPTR - LOWEST = IWORK(JPTR) - DO 4000 J = 1, KIN - IF (IWORK(JPTR).LT.LOWEST) THEN - LOWEST = IWORK(JPTR) - END IF - JPTR = JPTR + 1 - 4000 CONTINUE -C SAVE FIRST ORDER VALUE - CALL SBYTEC (IFOVAL,LOWEST,IFOPTR,KWIDE) - IFOPTR = IFOPTR + KWIDE -C PRINT *,'FOVAL',I,LOWEST,KWIDE -C SUBTRACT FIRST ORDER VALUE FROM OTHER VALS -C GETTING SECOND ORDER VALUES - JPTR = KPTR - IBIG = IWORK(JPTR) - LOWEST - DO 4200 J = 1, KIN - IWORK(JPTR) = IWORK(JPTR) - LOWEST - IF (IWORK(JPTR).GT.IBIG) THEN - IBIG = IWORK(JPTR) - END IF - JPTR = JPTR + 1 - 4200 CONTINUE -C HOW MANY BITS TO CONTAIN LARGEST SECOND -C ORDER VALUE IN SEGMENT - CALL FI7505 (IBIG,NWIDE) -C SAVE BIT WIDTH - CALL SBYTEC (ISOWID,NWIDE,IWDPTR,8) - IWDPTR = IWDPTR + 8 -C PRINT *,I,'SOVAL',IBIG,' IN',NWIDE,' BITS' -C WRITE (6,4101) (IWORK(K),K=KPTR,KPTR+52) -C SAVE SECOND ORDER VALUES OF THIS SEGMENT - DO 5000 J = 0, KIN-1 - CALL SBYTEC (ISOVAL,IWORK(KPTR+J),ISOPTR,NWIDE) - ISOPTR = ISOPTR + NWIDE - 5000 CONTINUE - KPTR = KPTR + KIN - 6000 CONTINUE -C ======================================================= -C CONCANTENATE ALL FIELDS FOR BDS -C -C REMAINDER GOES INTO IPFLD - IPTR = 0 -C BYTES 12-13 -C VALUE FOR N1 -C LEAVE SPACE FOR THIS - IPTR = IPTR + 16 -C BYTE 14 -C EXTENDED FLAGS - CALL SBYTEC (IPFLD,IBDSFL(5),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(6),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(7),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(8),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(9),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(10),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(11),IPTR,1) - IPTR = IPTR + 1 - CALL SBYTEC (IPFLD,IBDSFL(12),IPTR,1) - IPTR = IPTR + 1 -C BYTES 15-16 -C SKIP OVER VALUE FOR N2 - IPTR = IPTR + 16 -C BYTES 17-18 -C P1 - CALL SBYTEC (IPFLD,KBDS(17),IPTR,16) - IPTR = IPTR + 16 -C BYTES 19-20 -C P2 - CALL SBYTEC (IPFLD,KBDS(19),IPTR,16) - IPTR = IPTR + 16 -C BYTE 21 - RESERVED LOCATION - CALL SBYTEC (IPFLD,0,IPTR,8) - IPTR = IPTR + 8 -C BYTES 22 - ? -C WIDTHS OF SECOND ORDER PACKING - IX = (IWDPTR + 32) / 32 -C CALL SBYTESC (IPFLD,ISOWID,IPTR,32,0,IX) - ijk=IWDPTR/8 - jst=(iptr/8)+1 - ipfld(jst:jst+ijk)=ISOWID(1:ijk) - IPTR = IPTR + IWDPTR -C PRINT *,'ISOWID',IWDPTR,IX -C CALL BINARY (ISOWID,IX) -C -C NO SECONDARY BIT MAP - -C DETERMINE LOCATION FOR START -C OF FIRST ORDER PACKED VALUES - KBDS(12) = IPTR / 8 + 12 -C STORE LOCATION - CALL SBYTEC (IPFLD,KBDS(12),0,16) -C MOVE IN FIRST ORDER PACKED VALUES - IPASS = (IFOPTR + 32) / 32 -c CALL SBYTESC (IPFLD,IFOVAL,IPTR,32,0,IPASS) - ijk=(IFOPTR/8)+1 - jst=(iptr/8)+1 - ipfld(jst:jst+ijk)=ifoval(1:ijk) - IPTR = IPTR + IFOPTR -C PRINT *,'IFOVAL',IFOPTR,IPASS,KWIDE -C CALL BINARY (IFOVAL,IPASS) - IF (MOD(IPTR,8).NE.0) THEN - IPTR = IPTR + 8 - MOD(IPTR,8) - END IF -C PRINT *,'IFOPTR =',IFOPTR,' ISOPTR =',ISOPTR -C DETERMINE LOCATION FOR START -C OF SECOND ORDER VALUES - KBDS(15) = IPTR / 8 + 12 -C SAVE LOCATION OF SECOND ORDER VALUES - CALL SBYTEC (IPFLD,KBDS(15),24,16) -C MOVE IN SECOND ORDER PACKED VALUES - IX = (ISOPTR + 32) / 32 -C CALL SBYTESC (IPFLD,ISOVAL,IPTR,32,0,IX) - ijk=(ISOPTR/8)+1 - jst=(iptr/8)+1 - ipfld(jst:jst+ijk)=isoval(1:ijk) - IPTR = IPTR + ISOPTR -C PRINT *,'ISOVAL',ISOPTR,IX -C CALL BINARY (ISOVAL,IX) - NLEFT = MOD(IPTR+88,16) - IF (NLEFT.NE.0) THEN - NLEFT = 16 - NLEFT - IPTR = IPTR + NLEFT - END IF -C COMPUTE LENGTH OF DATA PORTION - LEN = IPTR / 8 -C COMPUTE LENGTH OF BDS - LENBDS = LEN + 11 -C ----------------------------------- -C BYTES 1-3 -C THIS FUNCTION COMPLETED BELOW -C WHEN LENGTH OF BDS IS KNOWN - CALL SBYTEC (BDS11,LENBDS,0,24) -C BYTE 4 - CALL SBYTEC (BDS11,IBDSFL(1),24,1) - CALL SBYTEC (BDS11,IBDSFL(2),25,1) - CALL SBYTEC (BDS11,IBDSFL(3),26,1) - CALL SBYTEC (BDS11,IBDSFL(4),27,1) -C ENTER NUMBER OF FILL BITS - CALL SBYTEC (BDS11,NLEFT,28,4) -C BYTE 5-6 - IF (ISCAL2.LT.0) THEN - CALL SBYTEC (BDS11,1,32,1) - ISCAL2 = - ISCAL2 - ELSE - CALL SBYTEC (BDS11,0,32,1) - END IF - CALL SBYTEC (BDS11,ISCAL2,33,15) -C -C FILL OCTET 7-10 WITH THE REFERENCE VALUE -C CONVERT THE FLOATING POINT OF YOUR MACHINE TO IBM370 32 BIT -C FLOATING POINT NUMBER -C REFERENCE VALUE -C FIRST TEST TO SEE IF -C ON 32 OR 64 BIT COMPUTER -C CALL W3FI01(LW) - IF (bit_size(LW).EQ.32) THEN - CALL W3FI76 (REFNCE,IEXP,IMANT,32) - ELSE - CALL W3FI76 (REFNCE,IEXP,IMANT,64) - END IF - CALL SBYTEC (BDS11,IEXP,48,8) - CALL SBYTEC (BDS11,IMANT,56,24) -C -C BYTE 11 -C - CALL SBYTEC (BDS11,KBDS(11),80,8) -C - KLEN = LENBDS / 4 + 1 -C PRINT *,'BDS11 LISTING',4,LENBDS -C CALL BINARY (BDS11,4) -C PRINT *,'IPFLD LISTING' -C CALL BINARY (IPFLD,KLEN) - RETURN - END - SUBROUTINE FI7505 (N,NBITS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI7505 DETERMINE NUMBER OF BITS TO CONTAIN VALUE -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 93-06-23 -C -C ABSTRACT: CALCULATE NUMBER OF BITS TO CONTAIN VALUE N, WITH A -C MAXIMUM OF 32 BITS. -C -C PROGRAM HISTORY LOG: -C 93-06-23 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL FI7505 (N,NBITS) -C INPUT ARGUMENT LIST: -C N - INTEGER VALUE -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C NBITS - NUMBER OF BITS TO CONTAIN N -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ - INTEGER N,NBITS - INTEGER IBITS(31) -C - DATA IBITS/1,3,7,15,31,63,127,255,511,1023,2047, - * 4095,8191,16383,32767,65535,131071,262143, - * 524287,1048575,2097151,4194303,8388607, - * 16777215,33554431,67108863,134217727,268435455, - * 536870911,1073741823,2147483647/ -C ---------------------------------------------------------------- -C - DO 1000 NBITS = 1, 31 - IF (N.LE.IBITS(NBITS)) THEN - RETURN - END IF - 1000 CONTINUE - RETURN - END - SUBROUTINE FI7513 (IWORK,ISTART,NPTS,MAX,MIN,INRNGE) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI7513 SELECT BLOCK OF DATA FOR PACKING -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 94-01-21 -C -C ABSTRACT: SELECT A BLOCK OF DATA FOR PACKING -C -C PROGRAM HISTORY LOG: -C 94-01-21 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL FI7513 (IWORK,ISTART,NPTS,MAX,MIN,INRNGE) -C INPUT ARGUMENT LIST: -C * - RETURN ADDRESS IF ENCOUNTER SET OF SAME VALUES -C IWORK - -C ISTART - -C NPTS - -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C MAX - -C MIN - -C INRNGE - -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ - INTEGER IWORK(*),NPTS,ISTART,INRNGE,INRNGA,INRNGB - INTEGER MAX,MIN,MXVAL,MAXB,MINB,MXVALB - INTEGER IBITS(31) -C - DATA IBITS/1,3,7,15,31,63,127,255,511,1023,2047, - * 4095,8191,16383,32767,65535,131071,262143, - * 524287,1048575,2097151,4194303,8388607, - * 16777215,33554431,67108863,134217727,268435455, - * 536870911,1073741823,2147483647/ -C ---------------------------------------------------------------- -C IDENTIFY NEXT BLOCK OF DATA FOR PACKING AND -C RETURN TO CALLER -C ******************************************************************** - ISTRTA = ISTART -C -C GET BLOCK A - CALL FI7516 (IWORK,NPTS,INRNGA,ISTRTA, - * MAX,MIN,MXVAL,LWIDE) -C ******************************************************************** -C - ISTRTB = ISTRTA + INRNGA - 2000 CONTINUE -C IF HAVE PROCESSED ALL DATA, RETURN - IF (ISTRTB.GT.NPTS) THEN -C NO MORE DATA TO LOOK AT - INRNGE = INRNGA - RETURN - END IF -C GET BLOCK B - CALL FI7502 (IWORK,ISTRTB,NPTS,ISAME) - IF (ISAME.GE.15) THEN -C PRINT *,'BLOCK B HAS ALL IDENTICAL VALUES' -C PRINT *,'BLOCK A HAS INRNGE =',INRNGA -C BLOCK B CONTAINS ALL IDENTICAL VALUES - INRNGE = INRNGA -C EXIT WITH BLOCK A - RETURN - END IF -C GET BLOCK B -C - ISTRTB = ISTRTA + INRNGA - CALL FI7516 (IWORK,NPTS,INRNGB,ISTRTB, - * MAXB,MINB,MXVALB,LWIDEB) -C PRINT *,'BLOCK A',INRNGA,' BLOCK B',INRNGB -C ******************************************************************** -C PERFORM TREND ANALYSIS TO DETERMINE -C IF DATA COLLECTION CAN BE IMPROVED -C - KTRND = LWIDE - LWIDEB -C PRINT *,'TREND',LWIDE,LWIDEB - IF (KTRND.LE.0) THEN -C PRINT *,'BLOCK A - SMALLER, SHOULD EXTEND INTO BLOCK B' - MXVAL = IBITS(LWIDE) -C -C IF BLOCK A REQUIRES THE SAME OR FEWER BITS -C LOOK AHEAD -C AND GATHER THOSE DATA POINTS THAT CAN -C BE RETAINED IN BLOCK A -C BECAUSE THIS BLOCK OF DATA -C USES FEWER BITS -C - CALL FI7518 (IRET,IWORK,NPTS,ISTRTA,INRNGA,INRNGB, - * MAX,MIN,LWIDE,MXVAL) - IF(IRET.EQ.1) GO TO 8000 -C PRINT *,'18 INRNGA IS NOW ',INRNGA - IF (INRNGB.LT.20) THEN - RETURN - ELSE - GO TO 2000 - END IF - ELSE -C PRINT *,'BLOCK A - LARGER, B SHOULD EXTEND BACK INTO A' - MXVALB = IBITS(LWIDEB) -C -C IF BLOCK B REQUIRES FEWER BITS -C LOOK BACK -C SHORTEN BLOCK A BECAUSE NEXT BLOCK OF DATA -C USES FEWER BITS -C - CALL FI7517 (IRET,IWORK,NPTS,ISTRTB,INRNGA, - * MAXB,MINB,LWIDEB,MXVALB) - IF(IRET.EQ.1) GO TO 8000 -C PRINT *,'17 INRNGA IS NOW ',INRNGA - END IF -C -C PACK UP BLOCK A -C UPDATA POINTERS - 8000 CONTINUE - INRNGE = INRNGA -C GET NEXT BLOCK A - 9000 CONTINUE - RETURN - END - SUBROUTINE FI7516 (IWORK,NPTS,INRNG,ISTART,MAX,MIN,MXVAL,LWIDTH) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI7516 SCAN NUMBER OF POINTS -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 94-01-21 -C -C ABSTRACT: SCAN FORWARD FROM CURRENT POSITION. COLLECT POINTS AND -C DETERMINE MAXIMUM AND MINIMUM VALUES AND THE NUMBER -C OF POINTS THAT ARE INCLUDED. FORWARD SEARCH IS TERMINATED -C BY ENCOUNTERING A SET OF IDENTICAL VALUES, BY REACHING -C THE NUMBER OF POINTS SELECTED OR BY REACHING THE END -C OF DATA. -C -C PROGRAM HISTORY LOG: -C 94-01-21 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL FI7516 (IWORK,NPTS,INRNG,ISTART,MAX,MIN,MXVAL,LWIDTH) -C INPUT ARGUMENT LIST: -C * - RETURN ADDRESS IF ENCOUNTER SET OF SAME VALUES -C IWORK - DATA ARRAY -C NPTS - NUMBER OF POINTS IN DATA ARRAY -C ISTART - STARTING LOCATION IN DATA -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C INRNG - NUMBER OF POINTS SELECTED -C MAX - MAXIMUM VALUE OF POINTS -C MIN - MINIMUM VALUE OF POINTS -C MXVAL - MAXIMUM VALUE THAT CAN BE CONTAINED IN LWIDTH BITS -C LWIDTH - NUMBER OF BITS TO CONTAIN MAX DIFF -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ - INTEGER IWORK(*),NPTS,ISTART,INRNG,MAX,MIN,LWIDTH,MXVAL - INTEGER IBITS(31) -C - DATA IBITS/1,3,7,15,31,63,127,255,511,1023,2047, - * 4095,8191,16383,32767,65535,131071,262143, - * 524287,1048575,2097151,4194303,8388607, - * 16777215,33554431,67108863,134217727,268435455, - * 536870911,1073741823,2147483647/ -C ---------------------------------------------------------------- -C - INRNG = 1 - JQ = ISTART + 19 - MAX = IWORK(ISTART) - MIN = IWORK(ISTART) - DO 1000 I = ISTART+1, JQ - CALL FI7502 (IWORK,I,NPTS,ISAME) - IF (ISAME.GE.15) THEN - GO TO 5000 - END IF - INRNG = INRNG + 1 - IF (IWORK(I).GT.MAX) THEN - MAX = IWORK(I) - ELSE IF (IWORK(I).LT.MIN) THEN - MIN = IWORK(I) - END IF - 1000 CONTINUE - 5000 CONTINUE - KRNG = MAX - MIN -C - DO 9000 LWIDTH = 1, 31 - IF (KRNG.LE.IBITS(LWIDTH)) THEN -C PRINT *,'RETURNED',INRNG,' VALUES' - RETURN - END IF - 9000 CONTINUE - RETURN - END - SUBROUTINE FI7517 (IRET,IWORK,NPTS,ISTRTB,INRNGA, - * MAXB,MINB,MXVALB,LWIDEB) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI7517 SCAN BACKWARD -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 94-01-21 -C -C ABSTRACT: SCAN BACKWARDS UNTIL A VALUE EXCEEDS RANGE OF GROUP B -C THIS MAY SHORTEN GROUP A -C -C PROGRAM HISTORY LOG: -C 94-01-21 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-06-17 IREDELL REMOVED ALTERNATE RETURN -C -C USAGE: CALL FI7517 (IRET,IWORK,NPTS,ISTRTB,INRNGA, -C * MAXB,MINB,MXVALB,LWIDEB) -C INPUT ARGUMENT LIST: -C IWORK - -C ISTRTB - -C NPTS - -C INRNGA - -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IRET - -C JLAST - -C MAXB - -C MINB - -C LWIDTH - NUMBER OF BITS TO CONTAIN MAX DIFF -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ - INTEGER IWORK(*),NPTS,ISTRTB,INRNGA - INTEGER MAXB,MINB,LWIDEB,MXVALB - INTEGER IBITS(31) -C - DATA IBITS/1,3,7,15,31,63,127,255,511,1023,2047, - * 4095,8191,16383,32767,65535,131071,262143, - * 524287,1048575,2097151,4194303,8388607, - * 16777215,33554431,67108863,134217727,268435455, - * 536870911,1073741823,2147483647/ -C ---------------------------------------------------------------- - IRET=0 -C PRINT *,' FI7517' - NPOS = ISTRTB - 1 - ITST = 0 - KSET = INRNGA -C - 1000 CONTINUE -C PRINT *,'TRY NPOS',NPOS,IWORK(NPOS),MAXB,MINB - ITST = ITST + 1 - IF (ITST.LE.KSET) THEN - IF (IWORK(NPOS).GT.MAXB) THEN - IF ((IWORK(NPOS)-MINB).GT.MXVALB) THEN -C PRINT *,'WENT OUT OF RANGE AT',NPOS - IRET=1 - RETURN - ELSE - MAXB = IWORK(NPOS) - END IF - ELSE IF (IWORK(NPOS).LT.MINB) THEN - IF ((MAXB-IWORK(NPOS)).GT.MXVALB) THEN -C PRINT *,'WENT OUT OF RANGE AT',NPOS - IRET=1 - RETURN - ELSE - MINB = IWORK(NPOS) - END IF - END IF - INRNGA = INRNGA - 1 - NPOS = NPOS - 1 - GO TO 1000 - END IF -C ---------------------------------------------------------------- -C - 9000 CONTINUE - RETURN - END - SUBROUTINE FI7518 (IRET,IWORK,NPTS,ISTRTA,INRNGA,INRNGB, - * MAXA,MINA,LWIDEA,MXVALA) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI7518 SCAN FORWARD -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 94-01-21 -C -C ABSTRACT: SCAN FORWARD FROM START OF BLOCK B TOWARDS END OF BLOCK B -C IF NEXT POINT UNDER TEST FORCES A LARGER MAXVALA THEN -C TERMINATE INDICATING LAST POINT TESTED FOR INCLUSION -C INTO BLOCK A. -C -C PROGRAM HISTORY LOG: -C 94-01-21 CAVANAUGH -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-06-17 IREDELL REMOVED ALTERNATE RETURN -C -C USAGE: CALL FI7518 (IRET,IWORK,NPTS,ISTRTA,INRNGA,INRNGB, -C * MAXA,MINA,LWIDEA,MXVALA) -C INPUT ARGUMENT LIST: -C IFLD - -C JSTART - -C NPTS - -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IRET - -C JLAST - -C MAX - -C MIN - -C LWIDTH - NUMBER OF BITS TO CONTAIN MAX DIFF -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916/256, Y-MP8/64, Y-MP EL92/256 -C -C$$$ - INTEGER IWORK(*),NPTS,ISTRTA,INRNGA - INTEGER MAXA,MINA,LWIDEA,MXVALA - INTEGER IBITS(31) -C - DATA IBITS/1,3,7,15,31,63,127,255,511,1023,2047, - * 4095,8191,16383,32767,65535,131071,262143, - * 524287,1048575,2097151,4194303,8388607, - * 16777215,33554431,67108863,134217727,268435455, - * 536870911,1073741823,2147483647/ -C ---------------------------------------------------------------- - IRET=0 -C PRINT *,' FI7518' - NPOS = ISTRTA + INRNGA - ITST = 0 -C - 1000 CONTINUE - ITST = ITST + 1 - IF (ITST.LE.INRNGB) THEN -C PRINT *,'TRY NPOS',NPOS,IWORK(NPOS),MAXA,MINA - IF (IWORK(NPOS).GT.MAXA) THEN - IF ((IWORK(NPOS)-MINA).GT.MXVALA) THEN -C PRINT *,'FI7518A -',ITST,' RANGE EXCEEDS MAX' - IRET=1 - RETURN - ELSE - MAXA = IWORK(NPOS) - END IF - ELSE IF (IWORK(NPOS).LT.MINA) THEN - IF ((MAXA-IWORK(NPOS)).GT.MXVALA) THEN -C PRINT *,'FI7518B -',ITST,' RANGE EXCEEDS MAX' - IRET=1 - RETURN - ELSE - MINA = IWORK(NPOS) - END IF - END IF - INRNGA = INRNGA + 1 -C PRINT *,' ',ITST,INRNGA - NPOS = NPOS +1 - GO TO 1000 - END IF -C ---------------------------------------------------------------- - 9000 CONTINUE - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi76.f b/external/w3nco/v2.0.6/src/w3fi76.f deleted file mode 100644 index 2a1553f51..000000000 --- a/external/w3nco/v2.0.6/src/w3fi76.f +++ /dev/null @@ -1,131 +0,0 @@ - SUBROUTINE W3FI76(PVAL,KEXP,KMANT,KBITS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI76 CONVERT TO IBM370 FLOATING POINT -C PRGMMR: REJONES ORG: NMC421 DATE:92-11-16 -C -C ABSTRACT: CONVERTS FLOATING POINT NUMBER FROM MACHINE -C REPRESENTATION TO GRIB REPRESENTATION (IBM370 32 BIT F.P.). -C -C PROGRAM HISTORY LOG: -C 85-09-15 JOHN HENNESSY ECMWF -C 92-09-23 JONES R. E. CHANGE NAME, ADD DOC BLOCK -C 93-10-27 JONES,R. E. CHANGE TO AGREE WITH HENNESSY CHANGES -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C 98-03-10 B. VUONG REMOVE THE CDIR$ INTEGER=64 DIRECTIVE -C -C USAGE: CALL W3FI76 (FVAL, KEXP, KMANT, NBITS) -C INPUT ARGUMENT LIST: -C PVAL - FLOATING POINT NUMBER TO BE CONVERTED -C KBITS - NUMBER OF BITS IN COMPUTER WORD (32 OR 64) -C -C OUTPUT ARGUMENT LIST: -C KEXP - 8 BIT SIGNED EXPONENT -C KMANT - 24 BIT MANTISSA (FRACTION) -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM370 VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS 9000, CRAY Y-MP8/864< CRAY Y-MP EL2/256 -C -C$$$ -C -C******************************************************************** -C* -C* NAME : CONFP3 -C* -C* FUNCTION : CONVERT FLOATING POINT NUMBER FROM MACHINE -C* REPRESENTATION TO GRIB REPRESENTATION. -C* -C* INPUT : PVAL - FLOATING POINT NUMBER TO BE CONVERTED. -C* KBITS : KBITS - NUMBER OF BITS IN COMPUTER WORD -C* -C* OUTPUT : KEXP - 8 BIT SIGNED EXPONENT -C* KMANT - 24 BIT MANTISSA -C* PVAL - UNCHANGED. -C* -C* JOHN HENNESSY , ECMWF 18.06.91 -C* -C******************************************************************** -C -C -C IMPLICIT NONE -C - INTEGER IEXP - INTEGER ISIGN -C - INTEGER KBITS - INTEGER KEXP - INTEGER KMANT -C - REAL PVAL - REAL ZEPS - REAL ZREF -C -C TEST FOR FLOATING POINT ZERO -C - IF (PVAL.EQ.0.0) THEN - KEXP = 0 - KMANT = 0 - GO TO 900 - ENDIF -C -C SET ZEPS TO 1.0E-12 FOR 64 BIT COMPUTERS (CRAY) -C SET ZEPS TO 1.0E-8 FOR 32 BIT COMPUTERS -C - IF (KBITS.EQ.32) THEN - ZEPS = 1.0E-8 - ELSE - ZEPS = 1.0E-12 - ENDIF - ZREF = PVAL -C -C SIGN OF VALUE -C - ISIGN = 0 - IF (ZREF.LT.0.0) THEN - ISIGN = 128 - ZREF = - ZREF - ENDIF -C -C EXPONENT -C - IEXP = INT(ALOG(ZREF)*(1.0/ALOG(16.0))+64.0+1.0+ZEPS) -C - IF (IEXP.LT.0 ) IEXP = 0 - IF (IEXP.GT.127) IEXP = 127 -C -C MANTISSA -C -C CLOSEST NUMBER IN GRIB FORMAT TO ORIGINAL NUMBER -C (EQUAL TO, GREATER THAN OR LESS THAN ORIGINAL NUMBER). -C - KMANT = NINT (ZREF/16.0**(IEXP-70)) -C -C CHECK THAT MANTISSA VALUE DOES NOT EXCEED 24 BITS -C 16777215 = 2**24 - 1 -C - IF (KMANT.GT.16777215) THEN - IEXP = IEXP + 1 -C -C CLOSEST NUMBER IN GRIB FORMAT TO ORIGINAL NUMBER -C (EQUAL TO, GREATER THAN OR LESS THAN ORIGINAL NUMBER). -C - KMANT = NINT (ZREF/16.0**(IEXP-70)) -C -C CHECK MANTISSA VALUE DOES NOT EXCEED 24 BITS AGAIN -C - IF (KMANT.GT.16777215) THEN - PRINT *,'BAD MANTISSA VALUE FOR PVAL = ',PVAL - ENDIF - ENDIF -C -C ADD SIGN BIT TO EXPONENT. -C - KEXP = IEXP + ISIGN -C - 900 CONTINUE -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi82.f b/external/w3nco/v2.0.6/src/w3fi82.f deleted file mode 100644 index 56a5ccc35..000000000 --- a/external/w3nco/v2.0.6/src/w3fi82.f +++ /dev/null @@ -1,97 +0,0 @@ - SUBROUTINE W3FI82 (IFLD,FVAL1,FDIFF1,NPTS,PDS,IGDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI82 CONVERT TO SECOND DIFF ARRAY -C PRGMMR: CAVANAUGH ORG: NMC421 DATE:93-08-18 -C -C ABSTRACT: ACCEPT AN INPUT ARRAY, CONVERT TO ARRAY OF SECOND -C DIFFERENCES. RETURN THE ORIGINAL FIRST VALUE AND THE FIRST -C FIRST-DIFFERENCE AS SEPARATE VALUES. ALIGN DATA IN -C BOUSTREPHEDONIC STYLE, (ALTERNATE ROW REVERSAL). -C -C PROGRAM HISTORY LOG: -C 93-07-14 CAVANAUGH -C 94-01-27 CAVANAUGH ADDED REVERSAL OF EVEN NUMBERED ROWS -C (BOUSTROPHEDONIC PROCESSING) -C 94-03-02 CAVANAUGH CORRECTED IMPROPER ORDERING OF EVEN -C NUMBERED ROWS -C 99-12-06 EBISUZAKI LINUX PORT -C -C USAGE: CALL W3FI82 (IFLD,FVAL1,FDIFF1,NPTS,PDS,IGDS) -C INPUT ARGUMENT LIST: -C IFLD - INTEGER INPUT ARRAY -C NPTS - NUMBER OF POINTS IN ARRAY -C IGDS(5) - NUMBER OF ROWS IN ARRAY -C IGDS(4) - NUMBER OF COLUMNS IN ARRAY -C PDS(8) - FLAG INDICATING PRESENCE OF GDS SECTION -C -C OUTPUT ARGUMENT LIST: -C IFLD - SECOND DIFFERENCED FIELD -C FVAL1 - FLOATING POINT ORIGINAL FIRST VALUE -C FDIFF1 - " " FIRST FIRST-DIFFERENCE -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: IBM370 VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916-128, CRAY Y-MP8/864, CRAY Y-MP EL2/256 -C -C$$$ -C - REAL FVAL1,FDIFF1 -C - INTEGER IFLD(*),NPTS,NBOUST(300),IGDS(*) -C - CHARACTER*1 PDS(*) -C -C --------------------------------------------- -C TEST FOR PRESENCE OF GDS -C -c looks like an error CALL GBYTE(PDS,IQQ,56,8) - call gbytec(PDS,IQQ,56,1) - IF (IQQ.NE.0) THEN - NROW = IGDS(5) - NCOL = IGDS(4) -C -C LAY OUT DATA BOUSTROPHEDONIC STYLE -C -C PRINT*, ' DATA SET UP BOUSTROPHEDON' -C - DO 210 I = 2, NROW, 2 -C -C REVERSE THE EVEN NUMBERED ROWS -C - DO 200 J = 1, NCOL - NPOS = I * NCOL - J + 1 - NBOUST(J) = IFLD(NPOS) - 200 CONTINUE - DO 201 J = 1, NCOL - NPOS = NCOL * (I-1) + J - IFLD(NPOS) = NBOUST(J) - 201 CONTINUE - 210 CONTINUE -C -C - END IF -C ================================================================= - DO 4000 I = NPTS, 2, -1 - IFLD(I) = IFLD(I) - IFLD(I-1) - 4000 CONTINUE - DO 5000 I = NPTS, 3, -1 - IFLD(I) = IFLD(I) - IFLD(I-1) - 5000 CONTINUE -C -C SPECIAL FOR GRIB -C FLOAT OUTPUT OF FIRST POINTS TO ANTICIPATE -C GRIB FLOATING POINT OUTPUT -C - FVAL1 = IFLD(1) - FDIFF1 = IFLD(2) -C -C SET FIRST TWO POINTS TO SECOND DIFF VALUE FOR BETTER PACKING -C - IFLD(1) = IFLD(3) - IFLD(2) = IFLD(3) -C ----------------------------------------------------------- - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi83.f b/external/w3nco/v2.0.6/src/w3fi83.f deleted file mode 100644 index 510c61e48..000000000 --- a/external/w3nco/v2.0.6/src/w3fi83.f +++ /dev/null @@ -1,108 +0,0 @@ - SUBROUTINE W3FI83 (DATA,NPTS,FVAL1,FDIFF1,ISCAL2, - * ISC10,KPDS,KGDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI83 RESTORE DELTA PACKED DATA TO ORIGINAL -C PRGMMR: CAVANAUGH ORG: NMC421 DATE:93-08-18 -C -C ABSTRACT: RESTORE DELTA PACKED DATA TO ORIGINAL VALUES -C RESTORE FROM BOUSTREPHEDONIC ALIGNMENT -C -C PROGRAM HISTORY LOG: -C 93-07-14 CAVANAUGH -C 93-07-22 STACKPOLE ADDITIONS TO FIX SCALING -C 94-01-27 CAVANAUGH ADDED REVERSAL OF EVEN NUMBERED ROWS -C (BOUSTROPHEDONIC PROCESSING) TO RESTORE -C DATA TO ORIGINAL SEQUENCE. -C 94-03-02 CAVANAUGH CORRECTED REVERSAL OF EVEN NUMBERED ROWS -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL W3FI83(DATA,NPTS,FVAL1,FDIFF1,ISCAL2, -C * ISC10,KPDS,KGDS) -C INPUT ARGUMENT LIST: -C DATA - SECOND ORDER DIFFERENCES -C NPTS - NUMBER OF POINTS IN ARRAY -C FVAL1 - ORIGINAL FIRST ENTRY IN ARRAY -C FDIFF1 - ORIGINAL FIRST FIRST-DIFFERENCE -C ISCAL2 - POWER-OF-TWO EXPONENT FOR UNSCALING -C ISC10 - POWER-OF-TEN EXPONENT FOR UNSCALING -C KPDS - ARRAY OF INFORMATION FOR PDS -C KGDS - ARRAY OF INFORMATION FOR GDS -C -C OUTPUT ARGUMENT LIST: -C DATA - EXPANDED ORIGINAL DATA VALUES -C -C REMARKS: SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: IBM VS FORTRAN 77, CRAY CFT77 FORTRAN -C MACHINE: HDS, CRAY C916-128, CRAY Y-MP8/864, CRAY Y-MP EL2/256 -C -C$$$ -C - REAL FVAL1,FDIFF1 - REAL DATA(*),BOUST(200) - INTEGER NPTS,NROW,NCOL,KPDS(*),KGDS(*),ISC10 -C --------------------------------------- -C -C REMOVE DECIMAL UN-SCALING INTRODUCED DURING UNPACKING -C - DSCAL = 10.0 ** ISC10 - IF (DSCAL.EQ.0.0) THEN - DO 50 I=1,NPTS - DATA(I) = 1.0 - 50 CONTINUE - ELSE IF (DSCAL.EQ.1.0) THEN - ELSE - DO 51 I=1,NPTS - DATA(I) = DATA(I) * DSCAL - 51 CONTINUE - END IF -C - DATA(1) = FVAL1 - DATA(2) = FDIFF1 - DO 200 J = 3,2,-1 - DO 100 K = J, NPTS - DATA(K) = DATA(K) + DATA(K-1) - 100 CONTINUE - 200 CONTINUE -C -C NOW REMOVE THE BINARY SCALING FROM THE RECONSTRUCTED FIELD -C AND THE DECIMAL SCALING TOO -C - IF (DSCAL.EQ.0) THEN - SCALE = 0.0 - ELSE - SCALE =(2.0**ISCAL2)/DSCAL - END IF - DO 300 I=1,NPTS - DATA(I) = DATA(I) * SCALE - 300 CONTINUE -C ========================================================== - IF (IAND(KPDS(4),128).NE.0) THEN - NROW = KGDS(3) - NCOL = KGDS(2) -C -C DATA LAID OUT BOUSTROPHEDONIC STYLE -C -C -C PRINT*, ' REVERSE BOUSTROPHEDON' - DO 210 I = 2, NROW, 2 -C -C REVERSE THE EVEN NUMBERED ROWS -C - DO 201 J = 1, NCOL - NPOS = I * NCOL - J + 1 - BOUST(J) = DATA(NPOS) - 201 CONTINUE - DO 202 J = 1, NCOL - NPOS = NCOL * (I-1) + J - DATA(NPOS) = BOUST(J) - 202 CONTINUE - 210 CONTINUE -C -C - END IF -C ================================================================= - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi88.f b/external/w3nco/v2.0.6/src/w3fi88.f deleted file mode 100644 index 72cde8bc0..000000000 --- a/external/w3nco/v2.0.6/src/w3fi88.f +++ /dev/null @@ -1,4750 +0,0 @@ - SUBROUTINE W3FI88(IPTR,IDENT,MSGA,ISTACK,MSTACK,KDATA,KNR,INDEX, - * LDATA,LSTACK,MAXR,MAXD,IUNITB,IUNITD) -C -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI88 BUFR MESSAGE DECODER -C PRGMMR: KEYSER ORG: NP22 DATE: 2001-02-01 -C -C ABSTRACT: THIS SET OF ROUTINES WILL DECODE A BUFR MESSAGE AND -C PLACE INFORMATION EXTRACTED FROM THE BUFR MESSAGE INTO SELECTED -C ARRAYS FOR THE USER. THE ARRAY KDATA CAN NOW BE SIZED BY THE USER -C BY INDICATING THE MAXIMUM NUMBER OF SUBSETS AND THE MAXIMUM -C NUMBER OF DESCRIPTORS THAT ARE EXPECTED IN THE COURSE OF DECODING -C SELECTED INPUT DATA. THIS ALLOWS FOR REALISTIC SIZING OF KDATA -C AND THE MSTACK ARRAYS. THIS VERSION ALSO ALLOWS FOR THE INCLUSION -C OF THE UNIT NUMBERS FOR TABLES B AND D INTO THE -C ARGUMENT LIST. THIS ROUTINE DOES NOT INCLUDE IFOD PROCESSING. -C -C PROGRAM HISTORY LOG: -C 1988-08-31 CAVANAUGH -C 1990-12-07 CAVANAUGH NOW UTILIZING GBYTE ROUTINES TO GATHER -C AND SEPARATE BIT FIELDS. THIS SHOULD IMPROVE -C (DECREASE) THE TIME IT TAKES TO DECODE ANY -C BUFR MESSAGE. HAVE ENTERED CODING THAT WILL -C PERMIT PROCESSING BUFR EDITIONS 1 AND 2. -C IMPROVED AND CORRECTED THE CONVERSION INTO -C IFOD FORMAT OF DECODED BUFR MESSAGES. -C 1991-01-18 CAVANAUGH PROGRAM/ROUTINES MODIFIED TO PROPERLY HANDLE -C SERIAL PROFILER DATA. -C 1991-04-04 CAVANAUGH MODIFIED TO HANDLE TEXT SUPPLIED THRU -C DESCRIPTOR 2 05 YYY. -C 1991-04-17 CAVANAUGH ERRORS IN EXTRACTING AND SCALING DATA -C CORRECTED. IMPROVED HANDLING OF NESTED -C QUEUE DESCRIPTORS IS ADDED. -C 1991-05-10 CAVANAUGH - ARRAY 'DATA' HAS BEEN ENLARGED TO REAL*8 -C TO BETTER CONTAIN VERY LARGE NUMBERS MORE -C ACCURATELY. THE PREIOUS SIZE REAL*4 COULD NOT -C CONTAIN SUFFICIENT SIGNIFICANT DIGITS. -C - CODING HAS BEEN INTRODUCED TO PROCESS NEW -C TABLE C DESCRIPTOR 2 06 YYY WHICH PERMITS IN -C LINE PROCESSING OF A LOCAL DESCRIPTOR EVEN IF -C THE DESCRIPTOR IS NOT CONTAINED IN THE USERS -C TABLE B. -C - A SECOND ROUTINE TO PROCESS IFOD MESSAGES -C (IFOD0) HAS BEEN REMOVED IN FAVOR OF THE -C IMPROVED PROCESSING OF THE ONE -C REMAINING (IFOD1). -C - NEW CODING HAS BEEN INTRODUCED TO PERMIT -C PROCESSING OF BUFR MESSAGES BASED ON BUFR -C EDITION UP TO AND INCLUDING EDITION 2. -C PLEASE NOTE INCREASED SIZE REQUIREMENTS -C FOR ARRAYS IDENT(20) AND IPTR(40). -C 1991-07-26 CAVANAUGH - ADD ARRAY MTIME TO CALLING SEQUENCE TO -C PERMIT INCLUSION OF RECEIPT/TRANSFER TIMES -C TO IFOD MESSAGES. -C 1991-09-25 CAVANAUGH - ALL PROCESSING OF DECODED BUFR DATA INTO -C IFOD (A LOCAL USE REFORMAT OF BUFR DATA) -C HAS BEEN ISOLATED FROM THIS SET OF ROUTINES. -C FOR THOSE INTERESTED IN THE IFOD FORM, -C SEE W3FL05 IN THE W3LIB ROUTINES. -C PROCESSING OF BUFR MESSAGES CONTAINING -C DELAYED REPLICATION HAS BEEN ALTERED SO THAT -C SINGLE SUBSETS (REPORTS) AND AND A MATCHING -C DESCRIPTOR LIST FOR THAT PARTICULAR SUBSET -C WILL BE PASSED TO THE USER WILL BE PASSED TO -C THE USER ONE AT A TIME TO ASSURE THAT EACH -C SUBSET CAN BE FULLY DEFINED WITH A MINIMUM -C OF REPROCESSING. -C PROCESSING OF ASSOCIATED FIELDS HAS BEEN -C TESTED WITH MESSAGES CONTAINING NON-COMPRESSED -C DATA. -C IN ORDER TO FACILITATE USER PROCESSING -C A MATCHING LIST OF SCALE FACTORS ARE INCLUDED -C WITH THE EXPANDED DESCRIPTOR LIST (MSTACK). -C 1991-11-21 CAVANAUGH - PROCESSING OF DESCRIPTOR 2 03 YYY -C HAS CORRECTED TO AGREE WITH FM94 STANDARDS. -C 1991-12-19 CAVANAUGH - CALLS TO FI8803 AND FI8804 HAVE BEEN -C CORRECTED TO AGREE CALLED PROGRAM ARGUMENT -C LIST. SOME ADDITIONAL ENTRIES HAVE BEEN -C INCLUDED FOR COMMUNICATING WITH DATA ACCESS -C ROUTINES. ADDITIONAL ERROR EXIT PROVIDED FOR -C THE CASE WHERE TABLE B IS DAMAGED. -C 1992-01-24 CAVANAUGH - ROUTINES FI8801, FI8803 AND FI8804 -C HAVE BEEN MODIFIED TO HANDLE ASSOCIATED FIELDS -C ALL DESCRIPTORS ARE SET TO ECHO TO MSTACK(1,N) -C 1992-05-21 CAVANAUGH - FURTHER EXPANSION OF INFORMATION COLLECTED -C FROM WITHIN UPPER AIR SOUNDINGS HAS PRODUCED -C THE NECESSITY TO EXPAND SOME OF THE PROCESSING -C AND OUTPUT ARRAYS. (SEE REMARKS BELOW) -C 1992-06-29 CAVANAUGH - CORRECTED DESCRIPTOR DENOTING HEIGHT OF -C EACH WIND LEVEL FOR PROFILER CONVERSIONS. -C 1992-07-23 CAVANAUGH - EXPANSION OF TABLE B REQUIRES ADJUSTMENT -C OF ARRAYS TO CONTAIN TABLE B VALUES NEEDED TO -C ASSIST IN THE DECODING PROCESS. -C ARRAYS CONTAINING DATA FROM TABLE B -C KFXY1 - DESCRIPTOR -C ANAME1 - DESCRIPTOR NAME -C AUNIT1 - UNITS FOR DESCRIPTOR -C ISCAL1 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL1 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE1 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C 1992-09-09 CAVANAUGH - FIRST ENCOUNTER WITH OPERATOR DESCRIPTOR -C 2 05 YYY SHOWED ERROR IN DECODING. THAT ERROR -C IS CORRECTED WITH THIS IMPLEMENTATION. FURTHER -C TESTING OF UPPER AIR DATA HAS ENCOUNTERED -C THE CONDITION OF LARGE (MANY LEVEL) SOUNDINGS -C ARRAYS IN THE DECODER HAVE BEEN EXPANDED (AGAIN) -C TO ALLOW FOR THIS CONDITION. -C 1992-10-02 CAVANAUGH - MODIFIED ROUTINE TO REFORMAT PROFILER DATA -C (FI8809) TO SHOW DESCRIPTORS, SCALE VALUE AND -C DATA IN PROPER ORDER. CORRECTED AN ERROR THAT -C PREVENTED USER FROM ASSIGNING THE SECOND DIMENSION -C OF KDATA(500,*). -C 1992-10-20 CAVANAUGH - REMOVED ERROR THAT PREVENTED FULL -C IMPLEMENTATION OF PREVIOUS CORRECTIONS AND -C MADE CORRECTIONS TO TABLE B TO BRING IT UP TO -C DATE. CHANGES INCLUDE PROPER REFORMAT OF PROFILER -C DATA AND USER CAPABILITY FOR ASSIGNING SECOND -C DIMENSION OF KDATA ARRAY. -C 1992-12-09 CAVANAUGH - THANKS TO DENNIS KEYSER FOR THE SUGGESTIONS -C AND CODING, THIS IMPLEMENTATION WILL ALLOW THE -C INCLUSION OF UNIT NUMBERS FOR TABLES B & D, AND -C IN ADDITION ALLOWS FOR REALISTIC SIZING OF KDATA -C AND MSTACK ARRAYS BY THE USER. AS OF THIS -C IMPLEMENTATION, THE UPPER SIZE LIMIT FOR A BUFR -C MESSAGE ALLOWS FOR A MESSAGE SIZE GREATER THAN -C 15000 BYTES. -C 1993-01-26 CAVANAUGH - ROUTINE FI8810 HAS BEEN ADDED TO PERMIT -C REFORMATTING OF PROFILER DATA IN EDITION 2. -C 1993-05-13 CAVANAUGH - ROUTINE FI8811 HAS BEEN ADDED TO PERMIT -C PROCESSING OF RUN-LINE ENCODING. THIS PROVIDES FOR -C THE HANDLING OF DATA FOR GRAPHICS PRODUCTS. -C PLEASE NOTE THE ADDITION OF TWO ARGUMENTS IN THE -C CALLING SEQUENCE. -C 1993-12-01 CAVANAUGH - ROUTINE FI8803 TO CORRECT HANDLING OF -C ASSOCIATED FIELDS AND ARRAYS ASSOCIATED WITH -C TABLE B ENTRIES ENLARGED TO HANDLE LARGER TABLE B -C 1994-05-25 CAVANAUGH - ROUTINES HAVE BEEN MODIFIED TO CONSTRUCT A -C MODIFIED TABLE B I.E., IT IS TAILORED TO CONTAIN O -C THOSE DESCRIPTORS THAT WILL BE USED TO DECODE -C DATA IN CURRENT AND SUBSEQUENT BUFR MESSAGES. -C TABLE B AND TABLE D DESCRIPTORS WILL BE ISOLATED -C AND MERGED WITH THE MAIN TABLES FOR USE WITH -C FOLLOWING BUFR MESSAGES. -C THE DESCRIPTORS INDICATING THE REPLICATION OF -C DESCRIPTORS AND DATA ARE ACTIVATED WITH THIS -C IMPLEMENTATION. -C 1994-08-30 CAVANAUGH - ADDED STATEMENTS THAT WILL ALLOW USE OF -C THESE ROUTINES DIRECTLY ON THE CRAY WITH NO -C MODIFICATION. HANDLING OD TABLE D ENTRIES HAS BEEN -C MODIFIED TO PREVENT LOSS OF ANCILLARY ENTRIES. -C CODING HAS BEEN ADDED TO ALLOW PROCESSING ON -C EITHER AN 8 BYTE WORD OR 4 BYTE WORD MACHINE. -C -C FOR THOSE USERS OF THE BUFR DECODER THAT ARE -C PROCESSING SETS OF BUFR MESSAGES THAT INCLUDE -C TYPE 11 MESSAGES, CODING HAS BEEN ADDED TO ALLOW -C THE RECOVERY OF THE ADDED OR MODIFIED TABLE B -C ENTRIES BY WRITING THEM TO A DISK FILE AVAILABLE -C TO THE USER. THIS IS ACCOMPLISHED WITH NO CHANGE -C TO THE CALLING SEQUENCE. TABLE B ENTRIES WILL BE -C DESIGNATED AS FOLLOWS: -C -C IUNITB - IS THE UNIT NUMBER FOR THE MASTER -C TABLE B. -C IUNITB+1 - WILL BE THE UNIT NUMBER FOR THE -C TABLE B ENTRIES THAT ARE TO BE USED -C IN THE DECODING OF SUBSEQUENT MESSAGES. -C THIS DEVICE WILL BE FORMATTED THE SAME -C THE DISK FILE ON IUNITB. -C -C 1995-06-07 KEYSER- CORRECTED AN ERROR WHICH REQUIRED INPUT -C ARGUMENT "MAXD" TO BE NEARLY TWICE AS LARGE AS -C NEEDED FOR DECODING WIND PROFILER REPORTS (LIMIT -C UPPER BOUND FOR "IWORK" ARRAY WAS SET TO "MAXD", -C NOW IT IS SET TO 15000). ALSO, A CORRECTION WAS -C MADE IN THE WIND PROFILER PROCESSING TO PREVENT -C UNNECESSARY LOOPING WHEN ALL REQUESTED -C DESCRIPTORS ARE MISSING. ALSO CORRECTED AN -C ERROR WHICH RESULTED IN RETURNED SCALE IN -C "MSTACK(2, ..)" ALWAYS BEING SET TO ZERO FOR -C COMPRESSED DATA. -C 1996-02-15 CAVANAUGH- MODIFIED IDENTIFICATION OF ASCII/EBCDIC -C MACHINE. MODIFIED HANDLING OF TABLE B TO PERMIT -C FASTER PROCESSING OF MULTIPLE MESSAGES WITH -C CHANGING DATA TYPES AND/OR SUBTYPES. -C 1996-04-02 CAVANAUGH- DEACTIVATED EXTRANEOUS WRITE STATEMENT. -C ENLARGED ARRAYS FOR TABLE B ENTRIES TO CONTAIN -C UP TO 1300 ENTRIES IN PREPARATION FOR NEW -C ADDITIONS TO TABLE B. -C 2001-02-01 KEYSER- THE TABLE B FILE WILL NOW BE READ WHENEVER THE -C INPUT ARGUMENT "IUNITB" (TABLE B UNIT NUMBER) -C CHANGES FROM ITS VALUE IN THE PREVIOUS CALL TO -C THIS ROUTINE (NORMALLY IT IS ONLY READ THE -C FIRST TIME THIS ROUTINE IS CALLED) -C 2002-10-15 VUONG REPLACED FUNCTION ICHAR WITH MOVA2I -C -C -C USAGE: CALL W3FI88(IPTR,IDENT,MSGA,ISTACK,MSTACK,KDATA,KNR,INDEX, -C LDATA,LSTACK,MAXR,MAXD,IUNITB,IUNITD) -C -C INPUT ARGUMENT LIST: -C MSGA - ARRAY CONTAINING SUPPOSED BUFR MESSAGE -C SIZE IS DETERMINED BY USER, CAN BE GREATER -C THAN 15000 BYTES. -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C IUNITB - UNIT NUMBER OF DATA SET HOLDING TABLE B, THIS IS THE -C NUMBER OF A PAIR OF DATA SETS -C IUNITB+1 - UNIT NUMBER FOR A DATASET TO CONTAIN TABLE B ENTRIES -C FROM MASTER TABLE B AND TABLE B ENTRIES EXTRACTED -C FROM TYPE 11 BUFR MESSAGES THAT WERE USED TO DECODE -C CURRENT BUFR MESSAGES. -C IUNITD - UNIT NUMBER OF DATA SET HOLDING TABLE D -C -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C ISTACK - ORIGINAL ARRAY OF DESCRIPTORS EXTRACTED FROM -C SOURCE BUFR MESSAGE. -C -C MSTACK(A,B)-LEVEL B - DESCRIPTOR NUMBER (LIMITED TO VALUE OF -C INPUT ARGUMENT MAXD) -C -C LEVEL A = 1 DESCRIPTOR -C = 2 10**N SCALING TO RETURN TO ORIGINAL VALUE -C IPTR - UTILITY ARRAY (SHOULD HAVE AT LAST 42 ENTRIES) -C IPTR( 1)- ERROR RETURN -C IPTR( 2)- BYTE COUNT SECTION 1 -C IPTR( 3)- POINTER TO START OF SECTION 1 -C IPTR( 4)- BYTE COUNT SECTION 2 -C IPTR( 5)- POINTER TO START OF SECTION 2 -C IPTR( 6)- BYTE COUNT SECTION 3 -C IPTR( 7)- POINTER TO START OF SECTION 3 -C IPTR( 8)- BYTE COUNT SECTION 4 -C IPTR( 9)- POINTER TO START OF SECTION 4 -C IPTR(10)- START OF REQUESTED SUBSET, RESERVED FOR DAR -C IPTR(11)- CURRENT DESCRIPTOR PTR IN IWORK -C IPTR(12)- LAST DESCRIPTOR POS IN IWORK -C IPTR(13)- LAST DESCRIPTOR POS IN ISTACK -C IPTR(14)- NUMBER OF MASTER TABLE B ENTRIES -C IPTR(15)- REQUESTED SUBSET POINTER, RESERVED FOR DAR -C IPTR(16)- INDICATOR FOR EXISTANCE OF SECTION 2 -C IPTR(17)- NUMBER OF REPORTS PROCESSED -C IPTR(18)- ASCII/TEXT EVENT -C IPTR(19)- POINTER TO START OF BUFR MESSAGE -C IPTR(20)- NUMBER OF ENTRIES FROM TABLE D -C IPTR(21)- NR TABLE B ENTRIES -C IPTR(22)- NR TABLE B ENTRIES FROM CURRENT MESSAGE -C IPTR(23)- CODE/FLAG TABLE SWITCH -C IPTR(24)- ADITIONAL WORDS ADDED BY TEXT INFO -C IPTR(25)- CURRENT BIT NUMBER -C IPTR(26)- DATA WIDTH CHANGE - ADD TO TABLE B WIDTH -C IPTR(27)- DATA SCALE CHANGE - MODIFIES TABLE B SCALE -C IPTR(28)- DATA REFERENCE VALUE CHANGE - ????????? -C IPTR(29)- ADD DATA ASSOCIATED FIELD -C IPTR(30)- SIGNIFY CHARACTERS -C IPTR(31)- NUMBER OF EXPANDED DESCRIPTORS IN MSTACK -C IPTR(32)- CURRENT DESCRIPTOR SEGMENT F -C IPTR(33)- CURRENT DESCRIPTOR SEGMENT X -C IPTR(34)- CURRENT DESCRIPTOR SEGMENT Y -C IPTR(35)- DATA/DESCRIPTOR REPLICATION IN PROGRESS -C 0 = NO -C 1 = YES -C IPTR(36)- NEXT DESCRIPTOR MAY BE UNDECIPHERABLE -C IPTR(37)- MACHINE TEXT TYPE FLAG -C 0 = EBCIDIC -C 1 = ASCII -C IPTR(38)- DATA/DESCRIPTOR REPLICATION FLAG -C 0 - DOES NOT EXIST IN CURRENT MESSAGE -C 1 - EXISTS IN CURRENT MESSAGE -C IPTR(39)- DELAYED REPLICATION FLAG -C 0 - NO DELAYED REPLICATION -C 1 - MESSAGE CONTAINS DELAYED REPLICATION -C IPTR(40)- NUMBER OF CHARACTERS IN TEXT FOR CURR DESCRIPTOR -C IPTR(41)- NUMBER OF ANCILLARY TABLE B ENTRIES -C IPTR(42)- NUMBER OF ANCILLARY TABLE D ENTRIES -C IPTR(43)- NUMBER OF ADDED TABLE B ENTRIES ENCOUNTERED WHILE -C PROCESSING A BUFR MESSAGE. THESE ENTRIES ONLY -C EXIST DURNG PROCESSING OF CURRENT BUFR MESSAGE -C IPTR(44)- BITS PER WORD -C IPTR(45)- BYTES PER WORD -C IDENT - ARRAY CONTAINS MESSAGE INFORMATION EXTRACTED FROM -C BUFR MESSAGE - -C IDENT(1) -EDITION NUMBER (BYTE 4, SECTION 1) -C IDENT(2) -ORIGINATING CENTER (BYTES 5-6, SECTION 1) -C IDENT(3) -UPDATE SEQUENCE (BYTE 7, SECTION 1) -C IDENT(4) -OPTIONAL SECTION (BYTE 8, SECTION 1) -C IDENT(5) -BUFR MESSAGE TYPE (BYTE 9, SECTION 1) -C 0 = SURFACE DATA (LAND) -C 1 = SURFACE DATA (SHIP) -C 2 = VERTICAL SOUNDINGS (OTHER THAN SATELLITE) -C 3 = VERTICAL SOUNDINGS (SATELLITE) -C 4 = SINGLE LVL UPPER-AIR DATA(OTHER THAN SATELLITE) -C 5 = SINGLE LEVEL UPPER-AIR DATA (SATELLITE) -C 6 = RADAR DATA -C 7 = SYNOPTIC FEATURES -C 8 = PHYSICAL/CHEMICAL CONSTITUENTS -C 9 = DISPERSAL AND TRANSPORT -C 10 = RADIOLOGICAL DATA -C 11 = BUFR TABLES (COMPLETE, REPLACEMENT OR UPDATE) -C 12 = SURFACE DATA (SATELLITE) -C 21 = RADIANCES (SATELLITE MEASURED) -C 31 = OCEANOGRAPHIC DATA -C IDENT(6) -BUFR MSG SUB-TYPE (BYTE 10, SECTION 1) -C TYPE SBTYP -C 2 7 = PROFILER -C IDENT(7) - (BYTES 11-12, SECTION 1) -C IDENT(8) -YEAR OF CENTURY (BYTE 13, SECTION 1) -C IDENT(9) -MONTH OF YEAR (BYTE 14, SECTION 1) -C IDENT(10)-DAY OF MONTH (BYTE 15, SECTION 1) -C IDENT(11)-HOUR OF DAY (BYTE 16, SECTION 1) -C IDENT(12)-MINUTE OF HOUR (BYTE 17, SECTION 1) -C IDENT(13)-RSVD BY ADP CENTERS(BYTE 18, SECTION 1) -C IDENT(14)-NR OF DATA SUBSETS (BYTE 5-6, SECTION 3) -C IDENT(15)-OBSERVED FLAG (BYTE 7, BIT 1, SECTION 3) -C IDENT(16)-COMPRESSION FLAG (BYTE 7, BIT 2, SECTION 3) -C IDENT(17)-MASTER TABLE NUMBER(BYTE 4, SECTION 1, ED 2 OR GTR) -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C INDEX - POINTER TO AVAILABLE SUBSET -C -C =========================================================== -C ARRAYS CONTAINING DATA FROM TABLE B -C NEW - BASE ARRAYS CONTAINING DATA FROM TABLE B -C KFXY1 - DECIMAL DESCRIPTOR VALUE OF F X Y VALUES -C ANAME1 - DESCRIPTOR NAME -C AUNIT1 - UNITS FOR DESCRIPTOR -C ISCAL1 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL1 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE1 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C =========================================================== -C NEW - ANCILLARY ARRAYS CONTAINING DATA FROM TABLE B -C CONTAINING TABLE B ENTRIES EXTRACTED -C FROM TYPE 11 BUFR MESSAGES -C KFXY2 - DECIMAL DESCRIPTOR VALUE OF F X Y VALUES -C ANAME2 - DESCRIPTOR NAME -C AUNIT2 - UNITS FOR DESCRIPTOR -C ISCAL2 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL2 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE2 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C =========================================================== -C NEW - ADDED ARRAYS CONTAINING DATA FROM TABLE B -C CONTAINING TABLE B ENTRIES EXTRACTED -C FROM NON-TYPE 11 BUFR MESSAGES -C THESE EXIST FOR THE LIFE OF CURRENT BUFR MESSAGE -C KFXY3 - DECIMAL DESCRIPTOR VALUE OF F X Y VALUES -C ANAME3 - DESCRIPTOR NAME -C AUNIT3 - UNITS FOR DESCRIPTOR -C ISCAL3 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL3 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE3 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C =========================================================== -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C UNIQUE - FI8801 FI8802 FI8803 FI8804 FI8805 FI8806 -C FI8807 FI8808 FI8809 FI8810 FI8811 FI8812 -C FI8813 FI8814 FI8815 FI8820 -C W3LIB - W3AI39 W3FC05 GBYTE GBYTES -C -C REMARKS: ERROR RETURNS: -C IPTR(1) = 1 'BUFR' NOT FOUND IN FIRST 125 CHARACTERS -C = 2 '7777' NOT FOUND IN LOCATION DETERMINED BY -C BY USING COUNTS FOUND IN EACH SECTION. ONE OR -C MORE SECTIONS HAVE AN ERRONEOUS BYTE COUNT OR -C CHARACTERS '7777' ARE NOT IN TEST MESSAGE. -C = 3 MESSAGE CONTAINS A DESCRIPTOR WITH F=0 THAT DOES -C NOT EXIST IN TABLE B. -C = 4 MESSAGE CONTAINS A DESCRIPTOR WITH F=3 THAT DOES -C NOT EXIST IN TABLE D. -C = 5 MESSAGE CONTAINS A DESCRIPTOR WITH F=2 WITH THE -C VALUE OF X OUTSIDE THE RANGE 1-6. -C = 6 DESCRIPTOR ELEMENT INDICATED TO HAVE A FLAG VALUE -C DOES NOT HAVE AN ENTRY IN THE FLAG TABLE. -C (TO BE ACTIVATED) -C = 7 DESCRIPTOR INDICATED TO HAVE A CODE VALUE DOES -C NOT HAVE AN ENTRY IN THE CODE TABLE. -C (TO BE ACTIVATED) -C = 8 ERROR READING TABLE D -C = 9 ERROR READING TABLE B -C = 10 ERROR READING CODE/FLAG TABLE -C = 11 DESCRIPTOR 2 04 004 NOT FOLLOWED BY 0 31 021 -C = 12 DATA DESCRIPTOR OPERATOR QUALIFIER DOES NOT FOLLOW -C DELAYED REPLICATION DESCRIPTOR. -C = 13 BIT WIDTH ON ASCII CHARACTERS NOT A MULTIPLE OF 8 -C = 14 SUBSETS = 0, NO CONTENT BULLETIN -C = 20 EXCEEDED COUNT FOR DELAYED REPLICATION PASS -C = 21 EXCEEDED COUNT FOR NON-DELAYED REPLICATION PASS -C = 22 EXCEEDED COMBINED BIT WIDTH, BIT WIDTH > 32 -C = 23 NO ELEMENT DESCRIPTORS FOLLOWING 2 03 YYY -C = 27 NON ZERO LOWEST ON TEXT DATA -C = 28 NBINC NOT NR OF CHARACTERS -C = 29 TABLE B APPEARS TO BE DAMAGED -C = 30 TABLE D ENTRY WITH MORE THAN 18 IN SEQUENCE -C BEING ENTERED FROM TYPE 11 MESSAGE -C = 99 NO MORE SUBSETS (REPORTS) AVAILABLE IN CURRENT -C BUFR MESAGE -C -C = 400 NUMBER OF SUBSETS EXCEEDS THE VALUE OF INPUT -C ARGUMENT MAXR; MUST INCREASE MAXR TO VALUE OF -C IDENT(14) IN CALLING PROGRAM -C -C = 401 NUMBER OF PARAMETERS (AND ASSOCIATED FIELDS) -C EXCEEDS LIMITS OF THIS PROGRAM. -C = 500 VALUE FOR NBINC HAS BEEN FOUND THAT EXCEEDS -C STANDARD WIDTH PLUS ANY BIT WIDTH CHANGE. -C CHECK ALL BIT WIDTHS UP TO POINT OF ERROR. -C = 501 CORRECTED WIDTH FOR DESCRIPTOR IS 0 OR LESS -C = 888 NON-NUMERIC CHARACTER IN CONVERSION REQUEST -C = 890 CLASS 0 ELEMENT DESCRIPTOR W/WIDTH OF 0 -C -C ON THE INITIAL CALL TO W3FI88 WITH A BUFR MESSAGE THE ARGUMENT -C INDEX MUST BE SET TO ZERO (INDEX = 0). ON THE RETURN FROM W3FI88 -C 'INDEX' WILL BE SET TO THE NEXT AVAILABLE SUBSET/REPORT. WHEN -C THERE ARE NO MORE SUBSETS AVAILABLE A 99 ERR RETURN WILL OCCUR. -C -C IF THE ORIGINAL BUFR MESSAGE DOES NOT CONTAIN DELAYED REPLICATION -C THE BUFR MESSAGE WILL BE COMPLETELY DECODED AND 'INDEX' WILL POINT -C TO THE FIRST DECODED SUBSET. THE USERS WILL THEN HAVE THE OPTION -C OF INDEXING THROUGH THE SUBSETS ON THEIR OWN OR BY RECALLING THIS -C ROUTINE (WITHOUT RESETTING 'INDEX') TO HAVE THE ROUTINE DO THE -C INDEXING. -C -C IF THE ORIGINAL BUFR MESSAGE DOES CONTAIN DELAYED REPLICATION -C ONE SUBSET/REPORT WILL BE DECODED AT A TIME AND PASSED BACK TO -C THE USER. THIS IS NOT AN OPTION. -C -C ============================================= -C TO USE THIS ROUTINE -C ============================================= -C THE ARRAYS TO CONTAIN THE OUTPUT INFORMATION ARE DEFINED -C AS FOLLOWS: -C -C KDATA(A,B) IS THE A DATA ENTRY (INTEGER VALUE) -C WHERE A IS THE MAXIMUM NUMBER OF REPORTS/SUBSETS -C THAT MAY BE CONTAINED IN THE BUFR MESSAGE (THIS -C IS NOW SET TO "MAXR" WHICH IS PASSED AS AN INPUT -C ARGUMENT TO W3FI88), AND WHERE B IS THE MAXIMUM -C NUMBER OF DESCRIPTOR COMBINATIONS THAT MAY -C BE PROCESSED (THIS IS NOW SET TO "MAXD" WHICH -C IS ALSO PASSED AS AN INPUT ARGUMENT TO W3FI88; -C UPPER AIR DATA AND SOME SATELLITE DATA REQUIRE -C A VALUE FOR MAXD OF 1700, BUT FOR MOST OTHER -C DATA A VALUE FOR MAXD OF 500 WILL SUFFICE) -C MSTACK(1,B) CONTAINS THE DESCRIPTOR THAT MATCHES THE -C DATA ENTRY (MAX. VALUE FOR B IS NOW "MAXD" -C WHICH IS PASSED AS AN INPUT ARGUMENT TO W3FI88) -C MSTACK(2,B) IS THE SCALE (POWER OF 10) TO BE APPLIED TO -C THE DATA (MAX. VALUE FOR B IS NOW "MAXD" -C WHICH IS PASSED AS AN INPUT ARGUMENT TO W3FI88) -C -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C -C -C THE MEMORY REQUIREMENTS FOR LSTACK AND LDATA ARE USED WITH -C RUN-LINE CODING PROVIDING FOR THE HANDLING OF DATA FOR -C GRAPHICS. I.E., RADAR DISPLAYS. IF THE DECODING PROCESS WILL -C NOT BE USED TO PROCESS THOSE TYPE OF MESSAGES, THEN THE -C VARIABLE SIZES FOR THE ARRAYS CAN BE MINIMIZED. -C IF THE DECODING PROCESS WILL BE USED TO DECODE THOSE MESSAGE -C TYPES, THEN MAXD MUST REFLECT THE MAXIMUM NUMBER OF -C DESCRIPTORS (FULLY EXPANDED LIST) TO BE EXPECTED IN THE -C MESSAGE. -C - INTEGER LDATA(MAXD) - INTEGER LSTACK(2,MAXD) -C - INTEGER MSGA(*) - INTEGER IPTR(*),KPTRB(16384),KPTRD(16384) - INTEGER KDATA(MAXR,MAXD) - INTEGER MSTACK(2,MAXD) -C - INTEGER IVALS(1000) - INTEGER KNR(MAXR) - INTEGER IDENT(*) - INTEGER ISTACK(*),IOLD11 -cdak KEYSER fix 02/02/2001 VVVVV - INTEGER IOLDTB -cdak KEYSER fix 02/02/2001 AAAAA - INTEGER IWORK(15000) - INTEGER INDEX -C - INTEGER IIII - CHARACTER*1 BLANK - CHARACTER*4 DIRID(2) -C - LOGICAL SEC2 -C .................................................. -C -C NEW BASE TABLE B -C MAY BE A COMBINATION OF MASTER TABLE B -C AND ANCILLARY TABLE B -C - INTEGER KFXY1(1300),ISCAL1(1300) - INTEGER IRFVL1(3,1300),IWIDE1(1300) - CHARACTER*40 ANAME1(1300) - CHARACTER*24 AUNIT1(1300) -C .................................................. -C -C NEW ANCILLARY TABLE B FROM TYPE 11 BUFR MESSAGE -C - INTEGER KFXY2(200),ISCAL2(200),IRFVL2(200),IWIDE2(200) - CHARACTER*64 ANAME2(200) - CHARACTER*24 AUNIT2(200) -C .................................................. -C -C NEW ADDED TABLE B FROM NON-TYPE 11 BUFR MESSAGE -C -C INTEGER KFXY3(200),ISCAL3(200),IRFVL3(200),IWIDE3(200) -C CHARACTER*64 ANAME3(200) -C CHARACTER*24 AUNIT3(200) -C .................................................. -C -C NEW BASE TABLE D -C - INTEGER ITBLD(20,400) -C .................................................. -C -C ANCILLARY TABLE D FROM TYPE 11 BUFR MESSAGE -C - INTEGER ITBLD2(20,50) -C .................................................. -C - SAVE - -cdak KEYSER fix 02/02/2001 VVVVV - DATA IOLD11/0/ - DATA IOLDTB/-99/ -cdak KEYSER fix 02/02/2001 AAAAA -C - CALL W3FI01(LW) - IPTR(45) = LW - IPTR(44) = LW * 8 -C - BLANK = ' ' - IF (MOVA2I(BLANK).EQ.32) THEN - IPTR(37) = 1 -C PRINT *,'ASCII MACHINE' - ELSE - IPTR(37) = 0 -C PRINT *,'EBCDIC MACHINE' - END IF -C -C PRINT *,' W3FI88 DECODER' -C INITIALIZE ERROR RETURN - IPTR(1) = 0 - IF (INDEX.GT.0) THEN -C HAVE RE-ENTRY - INDEX = INDEX + 1 -C PRINT *,'RE-ENTRY LOOKING FOR SUBSET NR',INDEX - IF (INDEX.GT.IDENT(14)) THEN -C ALL SUBSETS PROCESSED - IPTR(1) = 99 - IPTR(38) = 0 - IPTR(39) = 0 - ELSE IF (INDEX.LE.IDENT(14)) THEN - IF (IPTR(39).NE.0) THEN - DO 3000 J =1, IPTR(13) - IWORK(J) = ISTACK(J) - 3000 CONTINUE - IPTR(12) = IPTR(13) - CALL FI8801(IPTR,IDENT,MSGA,ISTACK,IWORK,KDATA,IVALS, - * MSTACK,KNR,INDEX,MAXR,MAXD, - * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1,IRF1SW,INEWVL, - * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2, - * KFXY3,ANAME3,AUNIT3,ISCAL3,IRFVL3,IWIDE3, - * IUNITB,IUNITD,ITBLD,ITBLD2,KPTRB,KPTRD) -C - END IF - END IF - RETURN - ELSE - INDEX = 1 -C PRINT *,'INITIAL ENTRY FOR THIS BUFR MESSAGE' - END IF - IPTR(39) = 0 -C FIND 'BUFR' IN FIRST 125 CHARACTERS - DO 1000 KNOFST = 0, 999, 8 - INOFST = KNOFST - CALL GBYTE (MSGA,IVALS,INOFST,8) - IF (IVALS(1).EQ.66) THEN - IPTR(19) = INOFST - INOFST = INOFST + 8 - CALL GBYTE (MSGA,IVALS,INOFST,24) - IF (IVALS(1).EQ.5588562) THEN -C PRINT *,'FOUND BUFR AT',IPTR(19) - INOFST = INOFST + 24 - GO TO 1500 - END IF - END IF - 1000 CONTINUE - PRINT *,'BUFR - START OF BUFR MESSAGE NOT FOUND' - IPTR(1) = 1 - RETURN - 1500 CONTINUE - IDENT(1) = 0 -C TEST FOR EDITION NUMBER -C ====================== - CALL GBYTE (MSGA,IDENT(1),INOFST+24,8) -C PRINT *,'THIS IS AN EDITION',IDENT(1),' BUFR MESSAGE' -C - IF (IDENT(1).GE.2) THEN -C GET TOTAL COUNT - CALL GBYTE (MSGA,IVALS,INOFST,24) - ITOTAL = IVALS(1) - KENDER = ITOTAL * 8 - 32 + IPTR(19) - CALL GBYTE (MSGA,ILAST,KENDER,32) -C IF (ILAST.EQ.926365495) THEN -C PRINT *,'HAVE TOTAL COUNT FROM SEC 0',IVALS(1) -C END IF - INOFST = INOFST + 32 -C GET SECTION 1 COUNT - IPTR(3) = INOFST - CALL GBYTE (MSGA,IVALS,INOFST,24) -C PRINT *,'SECTION 1 STARTS AT',INOFST,' SIZE',IVALS(1) - INOFST = INOFST + 24 - IPTR( 2) = IVALS(1) -C GET MASTER TABLE - CALL GBYTE (MSGA,IVALS,INOFST,8) - INOFST = INOFST + 8 - IDENT(17) = IVALS(1) -C PRINT *,'BUFR MASTER TABLE NR',IDENT(17) - ELSE - IPTR(3) = INOFST -C GET SECTION 1 COUNT - CALL GBYTE (MSGA,IVALS,INOFST,24) -C PRINT *,'SECTION 1 STARTS AT',INOFST,' SIZE',IVALS(1) - INOFST = INOFST + 32 - IPTR( 2) = IVALS(1) - END IF -C ====================== -C ORIGINATING CENTER - CALL GBYTE (MSGA,IVALS,INOFST,16) - INOFST = INOFST + 16 - IDENT(2) = IVALS(1) -C UPDATE SEQUENCE - CALL GBYTE (MSGA,IVALS,INOFST,8) - INOFST = INOFST + 8 - IDENT(3) = IVALS(1) -C OPTIONAL SECTION FLAG - CALL GBYTE (MSGA,IVALS,INOFST,1) - IDENT(4) = IVALS(1) - IF (IDENT(4).GT.0) THEN - SEC2 = .TRUE. - ELSE -C PRINT *,' NO OPTIONAL SECTION 2' - SEC2 = .FALSE. - END IF - INOFST = INOFST + 8 -C MESSAGE TYPE - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(5) = IVALS(1) - INOFST = INOFST + 8 -C MESSAGE SUBTYPE - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(6) = IVALS(1) - INOFST = INOFST + 8 -cdak KEYSER fix 02/02/2001 VVVVV - IF (IUNITB.NE.IOLDTB) THEN -C IF HAVE A CHANGE IN TABLE B UNIT NUMBER , READ TABLE B - IF(IOLDTB.NE.-99) PRINT *, 'W3FI88 - NEW TABLE B UNIT NUMBER' - IOLDTB = IUNITB - IPTR(14) = 0 - IPTR(21) = 0 - END IF -cdak KEYSER fix 02/02/2001 AAAAA -C IF HAVE CHANGE IN DATA TYPE , RESET TABLE B - IF (IOLD11.EQ.11) THEN - IOLD11 = IDENT(5) - IOLDSB = IDENT(6) -C JUST CONTINUE PROCESSING - ELSE IF (IOLD11.NE.11) THEN - IF (IDENT(5).EQ.11) THEN - IOLD11 = IDENT(5) - IPTR(21) = 0 - ELSE IF (IDENT(5).NE.IOLD11) THEN - IOLD11 = IDENT(5) - IPTR(21) = 0 - ELSE IF (IDENT(5).EQ.IOLD11) THEN -C IF HAVE A CHANGE IN SUBTYPE, RESET TABLE B - IF (IOLDSB.NE.IDENT(6)) THEN - IOLDSB = IDENT(6) - IPTR(21) = 0 -C ELSE IF - END IF - END IF - END IF -C IF BUFR EDITION 0 OR 1 THEN -C NEXT 2 BYTES ARE BUFR TABLE VERSION -C ELSE -C BYTE 11 IS VER NR OF MASTER TABLE -C BYTE 12 IS VER NR OF LOCAL TABLE - IF (IDENT(1).LT.2) THEN - CALL GBYTE (MSGA,IVALS,INOFST,16) - IDENT(7) = IVALS(1) - INOFST = INOFST + 16 - ELSE -C BYTE 11 IS VER NR OF MASTER TABLE - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(18) = IVALS(1) - INOFST = INOFST + 8 -C BYTE 12 IS VER NR OF LOCAL TABLE - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(19) = IVALS(1) - INOFST = INOFST + 8 - - END IF -C YEAR OF CENTURY - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(8) = IVALS(1) - INOFST = INOFST + 8 -C MONTH - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(9) = IVALS(1) - INOFST = INOFST + 8 -C DAY -C PRINT *,'DAY AT ',INOFST - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(10) = IVALS(1) - INOFST = INOFST + 8 -C HOUR - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(11) = IVALS(1) - INOFST = INOFST + 8 -C MINUTE - CALL GBYTE (MSGA,IVALS,INOFST,8) - IDENT(12) = IVALS(1) -C RESET POINTER (INOFST) TO START OF -C NEXT SECTION -C (SECTION 2 OR SECTION 3) - INOFST = IPTR(3) + IPTR(2) * 8 - IPTR(4) = 0 - IPTR(5) = INOFST - IF (SEC2) THEN -C SECTION 2 COUNT - CALL GBYTE (MSGA,IPTR(4),INOFST,24) - INOFST = INOFST + 32 -C PRINT *,'SECTION 2 STARTS AT',INOFST,' BYTES=',IPTR(4) - KENTRY = (IPTR(4) - 4) / 14 -C PRINT *,'SHOULD BE A MAX OF',KENTRY,' REPORTS' - IF (IDENT(2).EQ.7) THEN - DO 2000 I = 1, KENTRY - CALL GBYTE (MSGA,KDSPL ,INOFST,16) - INOFST = INOFST + 16 - CALL GBYTE (MSGA,LAT ,INOFST,16) - INOFST = INOFST + 16 - CALL GBYTE (MSGA,LON ,INOFST,16) - INOFST = INOFST + 16 - CALL GBYTE (MSGA,KDAHR ,INOFST,16) - INOFST = INOFST + 16 - CALL GBYTE (MSGA,DIRID(1),INOFST,32) - INOFST = INOFST + 32 - CALL GBYTE (MSGA,DIRID(2),INOFST,16) - INOFST = INOFST + 16 -C PRINT *,KDSPL,LAT,LON,KDAHR,DIRID(1),DIRID(2) - 2000 CONTINUE - END IF -C RESET POINTER (INOFST) TO START OF -C SECTION 3 - INOFST = IPTR(5) + IPTR(4) * 8 - END IF -C BIT OFFSET TO START OF SECTION 3 - IPTR( 7) = INOFST -C SECTION 3 COUNT - CALL GBYTE (MSGA,IPTR(6),INOFST,24) -C PRINT *,'SECTION 3 STARTS AT',INOFST,' BYTES=',IPTR(6) - INOFST = INOFST + 24 -C SKIP RESERVED BYTE - INOFST = INOFST + 8 -C NUMBER OF DATA SUBSETS - CALL GBYTE (MSGA,IDENT(14),INOFST,16) -C - IF (IDENT(14).GT.MAXR) THEN - PRINT *,'THE NUMBER OF SUBSETS EXCEEDS THE MAXIMUM OF',MAXR - PRINT *,'PASSED INTO W3FI88; MAXR MUST BE INCREASED IN ' - PRINT *,'THE CALLING PROGRAM TO AT LEAST THE VALUE OF' - PRINT *,IDENT(14),'TO BE ABLE TO PROCESS THIS DATA' -C - IPTR(1) = 400 - RETURN - END IF - INOFST = INOFST + 16 -C OBSERVED DATA FLAG - CALL GBYTE (MSGA,IVALS,INOFST,1) - IDENT(15) = IVALS(1) - INOFST = INOFST + 1 -C COMPRESSED DATA FLAG - CALL GBYTE (MSGA,IVALS,INOFST,1) - IDENT(16) = IVALS(1) - INOFST = INOFST + 7 -C CALCULATE NUMBER OF DESCRIPTORS - NRDESC = (IPTR( 6) - 8) / 2 - IPTR(12) = NRDESC - IPTR(13) = NRDESC -C EXTRACT DESCRIPTORS - CALL GBYTES (MSGA,ISTACK,INOFST,16,0,NRDESC) -C PRINT *,'INITIAL DESCRIPTOR LIST OF',NRDESC,' DESCRIPTORS' - DO 10 L = 1, NRDESC - IWORK(L) = ISTACK(L) -C PRINT *,L,ISTACK(L) - 10 CONTINUE - IPTR(13) = NRDESC -C =============================================================== -C -C CONSTRUCT A TABLE B TO MATCH THE -C LIST OF DESCRIPTORS FOR THIS MESSAGE -C - IF (IPTR(21).EQ.0) THEN - PRINT *,'W3FI88- TABLE B NOT YET ENTERED' - CALL FI8812(IPTR,IUNITB,IUNITD,ISTACK,NRDESC,KPTRB,KPTRD, - * IRF1SW,NEWREF,ITBLD,ITBLD2, - * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1, - * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2) - ELSE -C PRINT *,'W3FI88- TABLE B ALL READY IN PLACE' - IF (IPTR(41).NE.0) THEN -C PRINT *,'MERGE',IPTR(41),' ENTRIES INTO TABLE B' -C CALL FI8818(IPTR,KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1, -C * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2,KPTRB) - END IF - END IF - IF (IPTR(1).NE.0) RETURN -C ================================================================ -C RESET POINTER TO START OF SECTION 4 - INOFST = IPTR(7) + IPTR(6) * 8 -C BIT OFFSET TO START OF SECTION 4 - IPTR( 9) = INOFST -C SECTION 4 COUNT - CALL GBYTE (MSGA,IVALS,INOFST,24) -C PRINT *,'SECTION 4 STARTS AT',INOFST,' VALUE',IVALS(1) - IPTR( 8) = IVALS(1) - INOFST = INOFST + 32 -C SET FOR STARTING BIT OF DATA - IPTR(25) = INOFST -C FIND OUT IF '7777' TERMINATOR IS THERE - INOFST = IPTR(9) + IPTR(8) * 8 - CALL GBYTE (MSGA,IVALS,INOFST,32) -C PRINT *,'SECTION 5 STARTS AT',INOFST,' VALUE',IVALS(1) - IF (IVALS(1).NE.926365495) THEN - PRINT *,'BAD SECTION COUNT' - IPTR(1) = 2 - RETURN - ELSE - IPTR(1) = 0 - END IF -C - CALL FI8801(IPTR,IDENT,MSGA,ISTACK,IWORK,KDATA,IVALS, - * MSTACK,KNR,INDEX,MAXR,MAXD, - * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1,IRF1SW,INEWVL, - * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2, - * KFXY3,ANAME3,AUNIT3,ISCAL3,IRFVL3,IWIDE3, - * IUNITB,IUNITD,ITBLD,ITBLD2,KPTRB,KPTRD) -C -C PRINT *,'HAVE RETURNED FROM FI8801' - IF (IPTR(1).NE.0) THEN - RETURN - END IF -C FURTHER PROCESSING REQUIRED FOR PROFILER DATA - IF (IDENT(5).EQ.2) THEN - IF (IDENT(6).EQ.7) THEN -C PRINT *,'REFORMAT PROFILER DATA' -C -C DO 7151 I = 1, 40 -C IF (I.LE.20) THEN -C PRINT *,'IPTR(',I,')=',IPTR(I), -C * ' IDENT(',I,')= ',IDENT(I) -C ELSE -C PRINT *,'IPTR(',I,')=',IPTR(I) -C END IF -C7151 CONTINUE -C DO 152 I = 1, IPTR(31) -C PRINT *,MSTACK(1,I),MSTACK(2,I),(KDATA(J,I),J=1,5) -C 152 CONTINUE - IF (IDENT(1).LT.2) THEN - CALL FI8809(IDENT,MSTACK,KDATA,IPTR,MAXR,MAXD) - ELSE - CALL FI8810(IDENT,MSTACK,KDATA,IPTR,MAXR,MAXD) - END IF -C DO 151 I = 1, 40 -C IF (I.LE.20) THEN -C PRINT *,'IPTR(',I,')=',IPTR(I), -C * ' IDENT(',I,')= ',IDENT(I) -C ELSE -C PRINT *,'IPTR(',I,')=',IPTR(I) -C END IF -C 151 CONTINUE - IF (IPTR(1).NE.0) THEN - RETURN - END IF -C -C DO 154 I = 1, IPTR(31) -C PRINT *,I,MSTACK(1,I),MSTACK(2,I),KDATA(1,I),KDATA(2,I) -C 154 CONTINUE - END IF - END IF -C IF DATA/DESCRIPTOR REPLICATION FLAG IS ON, -C MUST COMPLETE EXPANSION OF DATA AND -C DESCRIPTORS. - IF (IPTR(38).EQ.1) THEN - CALL FI8811(IPTR,IDENT,MSTACK,KDATA,KNR, - * LDATA,LSTACK,MAXD,MAXR) - END IF -C -C IF HAVE A LIST OF TABLE ENTRIES FROM -C A BUFR MESSAGE TYPE 11 -C PRINT OUT THE ENTRIES -C - IF (IDENT(5).EQ.11) THEN -C DO 100 I = 1, IPTR(31)+IPTR(24) -C PRINT *,I,MSTACK(1,I),(KDATA(J,I),J=1,4) -C 100 CONTINUE - CALL FI8813 (IPTR,MAXR,MAXD,MSTACK,KDATA,IDENT,KPTRD,KPTRB, - * ITBLD,ANAME1,AUNIT1,KFXY1,ISCAL1,IRFVL1,IWIDE1,IUNITB) - END IF - RETURN - END - SUBROUTINE FI8801(IPTR,IDENT,MSGA,ISTACK,IWORK,KDATA,IVALS, - * MSTACK,KNR,INDEX,MAXR,MAXD, - * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1,IRF1SW,INEWVL, - * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2, - * KFXY3,ANAME3,AUNIT3,ISCAL3,IRFVL3,IWIDE3, - * IUNITB,IUNITD,ITBLD,ITBLD2,KPTRB,KPTRD) -C -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8801 DATA EXTRACTION -C PRGMMR: KEYSER ORG: NP22 DATE: 1995-06-07 -C -C ABSTRACT: CONTROL THE EXTRACTION OF DATA FROM SECTION 4 BASED ON -C DATA DESCRIPTORS. -C -C PROGRAM HISTORY LOG: -C 1988-09-01 CAVANAUGH -C 1991-01-18 CAVANAUGH CORRECTIONS TO PROPERLY HANDLE NON-COMPRESSED -C DATA. -C 1991-09-23 CAVANAUGH CODING ADDED TO HANDLE SINGLE SUBSETS WITH -C DELAYED REPLICATION. -C 1992-01-24 CAVANAUGH MODIFIED TO ECHO DESCRIPTORS TO MSTACK(1,N) -C 1995-06-07 KEYSER CORRECTED AN ERROR WHICH REQUIRED INPUT -C ARGUMENT "MAXD" TO BE NEARLY TWICE AS LARGE -C AS NEEDED FOR DECODING WIND PROFILER REPORTS -C (LIMIT UPPER BOUND FOR "IWORK" ARRAY WAS SET -C TO "MAXD", NOW IT IS SET TO 15000) -C -C USAGE: CALL FI8801(IPTR,IDENT,MSGA,ISTACK,IWORK,KDATA,IVALS, -C * MSTACK,KNR,INDEX,MAXR,MAXD, -C * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1,IRF1SW,INEWVL, -C * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2, -C * KFXY3,ANAME3,AUNIT3,ISCAL3,IRFVL3,IWIDE3, -C * IUNITB,IUNITD,ITBLD,ITBLD2,KPTRB) -C -C INPUT ARGUMENT LIST: -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C IDENT - SEE W3FI88 ROUTINE DOCBLOCK -C MSGA - ARRAY CONTAINING BUFR MESSAGE -C ISTACK - ORIGINAL ARRAY OF DESCRIPTORS EXTRACTED FROM -C SOURCE BUFR MESSAGE. -C MSTACK - WORKING ARRAY OF DESCRIPTORS (EXPANDED)AND SCALING -C FACTOR -C KFXY1 - IMAGE OF CURRENT DESCRIPTOR -C INDEX - -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C IUNITB - UNIT NUMBER OF DATA SET HOLDING TABLE B -C IUNITD - UNIT NUMBER OF DATA SET HOLDING TABLE D -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IWORK - WORKING DESCRIPTOR LIST -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C -C ISTACK - SEE ABOVE -C ARRAYS CONTAINING DATA FROM TABLE B -C KFXY1 - SEE ABOVE -C ANAME1 - DESCRIPTOR NAME -C AUNIT1 - UNITS FOR DESCRIPTOR -C ISCAL1 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL1 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE1 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - FI8802 FI8805 FI8806 FI8807 FI8808 -C -C REMARKS: ERROR RETURN: -C IPTR(1) = 8 ERROR READING TABLE B -C = 9 ERROR READING TABLE D -C = 11 ERROR OPENING TABLE B -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C .................................................. -C -C NEW ANCILLARY TABLE B FROM TYPE 11 BUFR MESSAGE -C - INTEGER KFXY2(*),ISCAL2(*),IRFVL2(*),IWIDE2(*) - CHARACTER*64 ANAME2(*) - CHARACTER*24 AUNIT2(*) -C .................................................. -C -C NEW ADDED TABLE B FROM NON-TYPE 11 BUFR MESSAGE -C - INTEGER KFXY3(200),ISCAL3(200),IRFVL3(200),IWIDE3(200) - CHARACTER*64 ANAME3(200) - CHARACTER*24 AUNIT3(200) -C .................................................. -C -C NEW BASE TABLE B -C MAY BE A COMBINATION OF MASTER TABLE B -C AND ANCILLARY TABLE B -C - INTEGER KFXY1(*),ISCAL1(*),IRFVL1(3,*),IWIDE1(*) - CHARACTER*40 ANAME1(*) - CHARACTER*24 AUNIT1(*) -C .................................................. -C -C ANCILLARY TABLE D FROM TYPE 11 BUFR MESSAGE -C - INTEGER ITBLD2(20,*) -C .................................................. -C -C NEW BASE TABLE D -C - INTEGER ITBLD(20,*) -C .................................................. -C -C - INTEGER MAXD, MAXR -C - INTEGER MSGA(*),KDATA(MAXR,MAXD),IVALS(*) -C - INTEGER KNR(MAXR) - INTEGER LX,LY,LL,J -C INTEGER IHOLD(33) - INTEGER IPTR(*),KPTRB(*),KPTRD(*) - INTEGER IDENT(*) - INTEGER ISTACK(*),IWORK(*) -C - INTEGER MSTACK(2,MAXD) -C - INTEGER JDESC - INTEGER INDEX -C - SAVE -C -C PRINT *,' DECOLL FI8801' - IF (INDEX.GT.1) THEN - GO TO 1000 - END IF -C --------- DECOLL --------------- - IPTR(23) = 0 - IPTR(26) = 0 - IPTR(27) = 0 - IPTR(28) = 0 - IPTR(29) = 0 - IPTR(30) = 0 - IPTR(36) = 0 -C INITIALIZE OUTPUT AREA -C SET POINTER TO BEGINNING OF DATA -C SET BIT - IPTR(17) = 1 - 1000 CONTINUE -C IPTR(12) = IPTR(13) - LL = 0 - IPTR(11) = 1 - IF (IPTR(10).EQ.0) THEN -C RE-ENTRY POINT FOR MULTIPLE -C NON-COMPRESSED REPORTS - ELSE - INDEX = IPTR(15) - IPTR(17) = INDEX - IPTR(25) = IPTR(10) - IPTR(10) = 0 - IPTR(15) = 0 - END IF -C PRINT *,'FI8801 - RPT',IPTR(17),' STARTS AT',IPTR(25) - IPTR(24) = 0 - IPTR(31) = 0 -C POINTING AT NEXT AVAILABLE DESCRIPTOR - MM = 0 - IF (IPTR(21).EQ.0) THEN - NRDESC = IPTR(13) - CALL FI8812(IPTR,IUNITB,IUNITD,ISTACK,NRDESC,KPTRB,KPTRD, - * IRF1SW,NEWREF,ITBLD,ITBLD2, - * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1, - * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2) - END IF - 10 CONTINUE -C PROCESS THRU THE FOLLOWING -C DEPENDING UPON THE VALUE OF 'F' (LF) - MM = MM + 1 - 12 CONTINUE - IF (MM.GT.MAXD) THEN - GO TO 200 - END IF -C END OF CYCLE TEST (SERIAL/SEQUENTIAL) - IF (IPTR(11).GT.IPTR(12)) THEN -C PRINT *,' HAVE COMPLETED REPORT SEQUENCE' - IF (IDENT(16).NE.0) THEN -C PRINT *,' PROCESSING COMPRESSED REPORTS' -C REFORMAT DATA FROM DESCRIPTOR -C FORM TO USER FORM - RETURN - ELSE -C WRITE (6,1) -C 1 FORMAT (1H1) -C PRINT *,' PROCESSED SERIAL REPORT',IPTR(17),IPTR(25) - IPTR(17) = IPTR(17) + 1 - IF (IPTR(17).GT.IDENT(14)) THEN - IPTR(17) = IPTR(17) - 1 - GO TO 200 - END IF - DO 300 I = 1, IPTR(13) - IWORK(I) = ISTACK(I) - 300 CONTINUE -C RESET POINTERS - LL = 0 - IPTR(1) = 0 - IPTR(11) = 1 - IPTR(12) = IPTR(13) -C IS THIS LAST REPORT ? -C PRINT *,'READY',IPTR(39),INDEX - IF (IPTR(39).GT.0) THEN - IF (INDEX.GT.0) THEN -C PRINT *,'HERE IS SUBSET NR',INDEX - RETURN - END IF - END IF - GO TO 1000 - END IF - END IF - 14 CONTINUE -C GET NEXT DESCRIPTOR - CALL FI8808 (IPTR,IWORK,LF,LX,LY,JDESC) -C PRINT *,IPTR(11)-1,'JDESC= ',JDESC,' AND NEXT ', -C * IPTR(11),IWORK(IPTR(11)),IPTR(31) -C PRINT *,IPTR(11)-1,'DESCRIPTOR',JDESC,LF,LX,LY, -C * ' FOR LOC',IPTR(17),IPTR(25) -CVVVVVCHANGE#2 FIX BY KEYSER -- 12/06/1994 -C NOTE: THIS FIX NEEDED BECAUSE IWORK ARRAY DOES NOT HAVE TO BE -C LIMITED TO SIZE OF "MAXD" -- WASTES SPACE BECAUSE "MAXD" -C MUST BECOME OVER TWICE AS LARGE AS NEEDED FOR PROFILERS -C IN ORDER TO AVOID SATISFYING THIS BELOW IF TEST -CDAK IF (IPTR(11).GT.MAXD) THEN - IF (IPTR(11).GT.15000) THEN -CAAAAACHANGE#2 FIX BY KEYSER -- 12/06/1994 - IPTR(1) = 401 - RETURN - END IF -C - KPRM = IPTR(31) + IPTR(24) - IF (KPRM.GT.MAXD) THEN - IF (KPRM.GT.KOLD) THEN - PRINT *,'EXCEEDED ARRAY SIZE',KPRM,IPTR(31), - * IPTR(24) - KOLD = KPRM - END IF - END IF -C REPLICATION PROCESSING - IF (LF.EQ.1) THEN -C ---------- F1 --------- - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(IPTR(17),KPRM) = 0 -C PRINT *,'FI8801-1',KPRM,MSTACK(1,KPRM), -C * MSTACK(2,KPRM),KDATA(IPTR(17),KPRM) - CALL FI8805(IPTR,IDENT,MSGA,IWORK,LX,LY, - * KDATA,LL,KNR,MSTACK,MAXR,MAXD) -C * KDATA,LL,KNR,MSTACK,MAXR,MAXD) - IF (IPTR(1).NE.0) THEN - RETURN - ELSE - GO TO 12 - END IF -C -C DATA DESCRIPTION OPERATORS - ELSE IF (LF.EQ.2)THEN - IF (LX.EQ.4) THEN - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(IPTR(17),KPRM) = 0 -C PRINT *,'FI8801-2',KPRM,MSTACK(1,KPRM), -C * MSTACK(2,KPRM),KDATA(IPTR(17),KPRM) - END IF - CALL FI8806 (IPTR,LX,LY,IDENT,MSGA,KDATA,IVALS,MSTACK, - * IWIDE1,IRFVL1,ISCAL1,J,LL,KFXY1,IWORK,JDESC,MAXR,MAXD, - * KPTRB) - IF (IPTR(1).NE.0) THEN - RETURN - END IF - GO TO 12 -C DESCRIPTOR SEQUENCE STRINGS - ELSE IF (LF.EQ.3) THEN -C PRINT *,'F3 SEQUENCE DESCRIPTOR' -C READ IN TABLE D, BUT JUST ONCE - IF (IPTR(20).EQ.0) THEN - CALL FI8820 (ITBLD,IUNITD,IPTR,ITBLD2,KPTRD) - IF (IPTR(1).GT.0) THEN - RETURN - END IF -C ELSE -C IF (IPTR(42).NE.0) THEN -C PRINT *,'MERGE',IPTR(42),' ENTRIES INTO TABLE D' -C CALL FI8819(IPTR,ITBLD,ITBLD2,KPTRD) -C END IF - END IF - CALL FI8807(IPTR,IWORK,ITBLD,ITBLD2,JDESC,KPTRD) - IF (IPTR(1).GT.0) THEN - RETURN - END IF - GO TO 14 -C -C ELEMENT DESCRIPTOR PROCESSING -C - ELSE - KPRM = IPTR(31) + IPTR(24) - CALL FI8802(IPTR,IDENT,MSGA,KDATA,KFXY1,LL,MSTACK, - * AUNIT1,IWIDE1,IRFVL1,ISCAL1,JDESC,IVALS,J,MAXR,MAXD, - * KPTRB) -C TURN OFF SKIP FLAG AFTER STD DESCRIPTOR - IPTR(36) = 0 - IF (IPTR(1).GT.0) THEN - RETURN - ELSE -C -C IF ENCOUNTER CLASS 0 DESCRIPTOR -C NOT CONTAINED WITHIN A BUFR -C MESSAGE OF TYPE 11, THEN COLLECT -C ALL TABLE B ENTRIES FOR USE ON -C CURRENT BUFR MESSAGE -C - IF (JDESC.LE.20.AND.JDESC.GE.10) THEN - IF (IDENT(5).NE.11) THEN -C COLLECT TABLE B ENTRIES - CALL FI8815(IPTR,IDENT,JDESC,KDATA, - * KFXY3,MAXR,MAXD,ANAME3,AUNIT3, - * ISCAL3,IRFVL3,IWIDE3, - * KEYSET,IBFLAG,IERR) - IF (IERR.NE.0) THEN - END IF - IF (IAND(IBFLAG,16).NE.0) THEN - IF (IAND(IBFLAG,8).NE.0) THEN - IF (IAND(IBFLAG,4).NE.0) THEN - IF (IAND(IBFLAG,2).NE.0) THEN - IF (IAND(IBFLAG,1).NE.0) THEN -C HAVE A COMPLETE TABLE B ENTRY - IPTR(43) = IPTR(43) + IDENT(14) - KEYSET = 0 - IBFLAG = 0 - GO TO 1000 - END IF - END IF - END IF - END IF - END IF - END IF - END IF - IF (IDENT(16).EQ.0) THEN - KNR(IPTR(17)) = IPTR(31) - ELSE - DO 310 KJ = 1, MAXR - KNR(KJ) = IPTR(31) - 310 CONTINUE - END IF - GO TO 10 - END IF - END IF -C END IF -C END DO WHILE - 200 CONTINUE -C IF (IDENT(16).NE.0) THEN -C PRINT *,'RETURN WITH',IDENT(14),' COMPRESSED REPORTS' -C ELSE -C PRINT *,'RETURN WITH',IPTR(17),' NON-COMPRESSED REPORTS' -C END IF - RETURN - END - SUBROUTINE FI8802(IPTR,IDENT,MSGA,KDATA,KFXY1,LL,MSTACK,AUNIT1, - * IWIDE1,IRFVL1,ISCAL1,JDESC,IVALS,J,MAXR,MAXD,KPTRB) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8802 PROCESS ELEMENT DESCRIPTOR -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 88-09-01 -C -C ABSTRACT: PROCESS AN ELEMENT DESCRIPTOR (F = 0) AND STORE DATA -C IN OUTPUT ARRAY. -C -C PROGRAM HISTORY LOG: -C 88-09-01 CAVANAUGH -C 91-04-04 CAVANAUGH CHANGED TO PASS WIDTH OF TEXT FIELDS IN BYTES -C -C USAGE: CALL FI8802(IPTR,IDENT,MSGA,KDATA,KFXY1,LL,MSTACK,AUNIT1, -C IWIDE1,IRFVL1,ISCAL1,JDESC,IVALS,J,MAXR,MAXD,KPTRB) -C INPUT ARGUMENT LIST: -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C IDENT - SEE W3FI88 ROUTINE DOCBLOCK -C MSGA - ARRAY CONTAINING BUFR MESSAGE -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C KFXY1 - IMAGE OF CURRENT DESCRIPTOR -C ANAME1 - LIST OF NAME OF DESCRIPTOR CONTENTS -C MSTACK - -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KDATA - SEE ABOVE -C KFXY1 - SEE ABOVE -C ARRAYS CONTAINING DATA FROM TABLE B -C AUNIT1 - UNITS FOR DESCRIPTOR -C ISCAL1 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL1 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE1 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - FI8803 FI8804 -C -C REMARKS: ERROR RETURN: -C IPTR(1) = 3 - MESSAGE CONTAINS A DESCRIPTOR WITH F=0 -C THAT DOES NOT EXIST IN TABLE B. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C TABLE B ENTRY - CHARACTER*24 ASKEY - INTEGER MSGA(*) - INTEGER IPTR(*) - INTEGER KPTRB(*) - INTEGER IDENT(*) - INTEGER J - INTEGER JDESC - INTEGER MSTACK(2,MAXD) - INTEGER KDATA(MAXR,MAXD),IVALS(*) -C .................................................. -C -C NEW BASE TABLE B -C MAY BE A COMBINATION OF MASTER TABLE B -C AND ANCILLARY TABLE B -C - INTEGER KFXY1(*),ISCAL1(*),IRFVL1(3,*),IWIDE1(*) -C CHARACTER*40 ANAME1(*) - CHARACTER*24 AUNIT1(*) -C .................................................. - SAVE -C - DATA ASKEY /'CCITT IA5 '/ -C -C PRINT *,' FI8802 - ELEMENT DESCRIPTOR ',JDESC,KPTRB(JDESC) -C FIND TABLE B ENTRY - J = KPTRB(JDESC) -C HAVE A MATCH -C SET FLAG IF TEXT EVENT -C PRINT *,'ASKEY=',ASKEY,'AUNIT1(',J,')=',AUNIT1(J),JDESC - IF (ASKEY(1:9).EQ.AUNIT1(J)(1:9)) THEN - IPTR(18) = 1 - IPTR(40) = IWIDE1(J) / 8 - ELSE - IPTR(18) = 0 - END IF -C PRINT *,'FI8802 - BIT WIDTH =',IWIDE1(J),IPTR(18),' FOR',JDESC - IF (IDENT(16).NE.0) THEN -C COMPRESSED - CALL FI8803(IPTR,IDENT,MSGA,KDATA,IVALS,MSTACK, - * IWIDE1,IRFVL1,ISCAL1,J,JDESC,MAXR,MAXD) -C IF (IPTR(1).NE.0) THEN -C RETURN -C END IF - ELSE -C NOT COMPRESSED -C PRINT *,' FROM FI8802',J - CALL FI8804(IPTR,MSGA,KDATA,IVALS,MSTACK, - * IWIDE1,IRFVL1,ISCAL1,J,LL,JDESC,MAXR,MAXD) -C IF (IPTR(1).NE.0) THEN -C RETURN -C END IF - END IF - RETURN - END -C ----------------------------------------------------- - SUBROUTINE FI8803(IPTR,IDENT,MSGA,KDATA,IVALS,MSTACK, - * IWIDE1,IRFVL1,ISCAL1,J,JDESC,MAXR,MAXD) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8803 PROCESS COMPRESSED DATA -C PRGMMR: KEYSER ORG: NP22 DATE: 1995-06-07 -C -C ABSTRACT: PROCESS COMPRESSED DATA AND PLACE INDIVIDUAL ELEMENTS -C INTO OUTPUT ARRAY. -C -C PROGRAM HISTORY LOG: -C 1988-09-01 CAVANAUGH -C 1991-04-04 CAVANAUGH TEXT HANDLING PORTION OF THIS ROUTINE -C MODIFIED TO HANLE WIDTH OF FIELDS IN BYTES. -C 1991-04-17 CAVANAUGH TESTS SHOWED THAT THE SAME DATA IN COMPRESSED -C AND UNCOMPRESSED FORM GAVE DIFFERENT RESULTS. -C THIS HAS BEEN CORRECTED. -C 1991-06-21 CAVANAUGH PROCESSING OF TEXT DATA HAS BEEN CHANGED TO -C PROVIDE EXACT REPRODUCTION OF ALL CHARACTERS. -C 1994-04-11 CAVANAUGH CORRECTED PROCESSING OF DATA WHEN ALL VALUES -C THE SAME (NBINC = 0). CORRECTED TEST OF LOWEST -C VALUE AGAINST PROPER BIT MASK. -C 1995-06-07 KEYSER CORRECTED AN ERROR WHICH RESULTED IN -C RETURNED SCALE IN "MSTACK(2, ..)" ALWAYS -C BEING SET TO ZERO FOR COMPRESSED DATA. ALSO, -C SCALE CHANGES WERE NOT BEING RECOGNIZED. -C -C USAGE: CALL FI8803(IPTR,IDENT,MSGA,KDATA,IVALS,MSTACK, -C IWIDE1,IRFVL1,ISCAL1,J,JDESC,MAXR,MAXD) -C INPUT ARGUMENT LIST: -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C IDENT - SEE W3FI88 ROUTINE DOCBLOCK -C MSGA - ARRAY CONTAINING BUFR MESSAGE,MSTACK, -C IVALS - ARRAY OF SINGLE PARAMETER VALUES -C J - -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C J - -C ARRAYS CONTAINING DATA FROM TABLE B -C ISCAL1 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL1 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE1 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - GBYTE GBYTES W3AI39 -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C -C .................................................. -C -C NEW BASE TABLE B -C MAY BE A COMBINATION OF MASTER TABLE B -C AND ANCILLARY TABLE B -C -C INTEGER KFXY1(*) - INTEGER ISCAL1(*) - INTEGER IRFVL1(3,*) - INTEGER IWIDE1(*) -C CHARACTER*40 ANAME1(*) -C CHARACTER*24 AUNIT1(*) -C .................................................. - INTEGER MAXD,MAXR - INTEGER MSGA(*),JDESC,MSTACK(2,MAXD) - INTEGER IPTR(*),IVALS(*),KDATA(MAXR,MAXD) - INTEGER NRVALS,JWIDE,IDATA - INTEGER IDENT(*) - INTEGER J - INTEGER KLOW(256) -C - LOGICAL TEXT -C - INTEGER MSK(32) -C - SAVE -C - DATA MSK /1, 3, 7, 15, 31, 63, 127, -C 1 2 3 4 5 6 7 - * 255, 511, 1023, 2047, 4095, -C 8 9 10 11 12 - * 8191, 16383, 32767, 65535, -C 13 14 15 16 - * 131071, 262143, 524287, -C 17 18 19 - * 1048575, 2097151, 4194303, -C 20 21 22 - * 8388607, 16777215, 33554431, -C 23 24 25 - * 67108863, 134217727, 268435455, -C 26 27 28 - * 536870911, 1073741823, 2147483647,-1 / -C 29 30 31 32 - CALL W3FI01(LW) - MWDBIT = IPTR(44) - IF (IPTR(45).EQ.8) THEN - I = 2147483647 - MSK(32) = I + I + 1 - END IF -C -C PRINT *,' FI8803 COMPR J=',J,' IWIDE1(J) =',IWIDE1(J), -C * ' EXTRA BITS =',IPTR(26),' START AT',IPTR(25) - IF (IPTR(18).EQ.0) THEN - TEXT = .FALSE. - ELSE - TEXT = .TRUE. - END IF -C PRINT *,'DESCRIPTOR',KPRM,JDESC - IF (.NOT.TEXT) THEN - IF (IPTR(29).GT.0.AND.JDESC.NE.7957) THEN -C PRINT *,'ASSOCIATED FIELD AT',IPTR(25) -C WORKING WITH ASSOCIATED FIELDS HERE - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) -C GET LOWEST - CALL GBYTE (MSGA,LOWEST,IPTR(25),IPTR(29)) - IPTR(25) = IPTR(25) + IPTR(29) -C GET NBINC - CALL GBYTE (MSGA,NBINC,IPTR(25),6) - IPTR(25) = IPTR(25) + 6 -C PRINT *,'LOWEST=',LOWEST,' NBINC=',NBINC - IF (NBINC.GT.32) THEN - IPTR(1) = 22 - RETURN - END IF -C EXTRACT DATA FOR ASSOCIATED FIELD - IF (NBINC.GT.0) THEN - CALL GBYTES (MSGA,IVALS,IPTR(25),NBINC,0,IPTR(21)) - IPTR(25) = IPTR(25) + NBINC * IPTR(21) - DO 50 I = 1, IDENT(14) - KDATA(I,KPRM) = IVALS(I) + LOWEST - IF (NBINC.EQ.32) THEN - IF (KDATA(I,KPRM).EQ.MSK(NBINC)) THEN - KDATA(I,KPRM) = 999999 - END IF - ELSE IF (KDATA(I,KPRM).GE.MSK(NBINC)) THEN - KDATA(I,KPRM) = 999999 - END IF - 50 CONTINUE - ELSE - DO 51 I = 1, IDENT(14) - KDATA(I,KPRM) = LOWEST - IF (NBINC.EQ.32) THEN - IF (LOWEST.EQ.MSK(32)) THEN - KDATA(I,KPRM) = 999999 - END IF - ELSE IF(LOWEST.GE.MSK(NBINC)) THEN - KDATA(I,KPRM) = 999999 - END IF - 51 CONTINUE - END IF - END IF -C SET PARAMETER -C ISOLATE COMBINED BIT WIDTH - JWIDE = IWIDE1(J) + IPTR(26) -C - IF (JWIDE.GT.32) THEN -C TOO MANY BITS IN COMBINED -C BIT WIDTH - PRINT *,'ERR 22 - HAVE EXCEEDED COMBINED BIT WIDTH' - IPTR(1) = 22 - RETURN - END IF -C SINGLE VALUE FOR LOWEST - NRVALS = 1 -C LOWEST -C PRINT *,'PARAM',KPRM - CALL GBYTE (MSGA,LOWEST,IPTR(25),JWIDE) -C PRINT *,' LOWEST=',LOWEST,' AT BIT LOC ',IPTR(25) - IPTR(25) = IPTR(25) + JWIDE -C ISOLATE COMPRESSED BIT WIDTH - CALL GBYTE (MSGA,NBINC,IPTR(25),6) -C PRINT *,' NBINC=',NBINC,' AT BIT LOC',IPTR(25) - IF (NBINC.GT.32) THEN -C NBINC TOO LARGE - IPTR(1) = 22 - RETURN - END IF - IF (IPTR(32).EQ.2.AND.IPTR(33).EQ.5) THEN - ELSE - IF (NBINC.GT.JWIDE) THEN -C PRINT *,'FOR DESCRIPTOR',JDESC -C PRINT *,J,'NBINC=',NBINC,' LOWEST=',LOWEST,' IWIDE1(J)=', -C * IWIDE1(J),' IPTR(26)=',IPTR(26),' AT BIT LOC',IPTR(25) -C DO 110 I = 1, KPRM -C WRITE (6,111)I,(KDATA(J,I),J=1,6) -C 110 CONTINUE -C 111 FORMAT (1X,5HDATA ,I3,6(2X,I10)) - IPTR(1) = 500 - PRINT *,'NBINC CALLS FOR LARGER BIT WIDTH THAN TABLE', - * ' B PLUS WIDTH CHANGES' - END IF - END IF - IPTR(25) = IPTR(25) + 6 -C PRINT *,'LOWEST',LOWEST,' NBINC=',NBINC -C IF TEXT EVENT, PROCESS TEXT -C GET COMPRESSED VALUES -C PRINT *,'COMPRESSED VALUES - NONTEXT' - NRVALS = IDENT(14) - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - IF (NBINC.NE.0) THEN - CALL GBYTES (MSGA,IVALS,IPTR(25),NBINC,0,NRVALS) - IPTR(25) = IPTR(25) + NBINC * NRVALS -C RECALCULATE TO ORIGINAL VALUES - DO 100 I = 1, NRVALS -C PRINT *,IVALS(I),MSK(NBINC),NBINC - IF (IVALS(I).GE.MSK(NBINC)) THEN - KDATA(I,KPRM) = 999999 - ELSE - IF (IRFVL1(2,J).EQ.0) THEN - JRV = IRFVL1(1,J) - ELSE - JRV = IRFVL1(3,J) - END IF - KDATA(I,KPRM) = IVALS(I) + LOWEST + JRV - END IF - 100 CONTINUE -C PRINT *,I,JDESC,LOWEST,IRFVL1(1,J),IRFVL1(3,J) - ELSE - IF (LOWEST.EQ.MSK(JWIDE)) THEN - DO 105 I = 1, NRVALS - KDATA(I,KPRM) = 999999 - 105 CONTINUE - ELSE - IF (IRFVL1(2,J).EQ.0) THEN - JRV = IRFVL1(1,J) - ELSE - JRV = IRFVL1(3,J) - END IF - ICOMB = LOWEST + JRV - DO 106 I = 1, NRVALS - KDATA(I,KPRM) = ICOMB - 106 CONTINUE - END IF - END IF -C PRINT *,'KPRM=',KPRM,' IPTR(25)=',IPTR(25) - MSTACK(1,KPRM) = JDESC -C WRITE (6,80) (KDATA(I,KPRM),I=1,10) - 80 FORMAT(2X,10(F10.2,1X)) -CVVVVVCHANGE#3 FIX BY KEYSER -- 12/06/1994 -C NOTE: THIS FIX NEEDED BECAUSE THE RETURNED SCALE IN MSTACK(2,..) -C WAS ALWAYS '0' FOR COMPRESSED DATA, INCL. CHANGED SCALES) - MSTACK(2,KPRM) = ISCAL1(J) + IPTR(27) -CAAAAACHANGE#3 FIX BY KEYSER -- 12/06/1994 - ELSE IF (TEXT) THEN -C PRINT *,' FOUND TEXT MODE IN COMPRESSED DATA',IPTR(40) -C GET LOWEST -C PRINT *,' PICKED UP LOWEST',(KLOW(K),K=1,IPTR(40)) - DO 1906 K = 1, IPTR(40) - CALL GBYTE (MSGA,KLOW,IPTR(25),8) - IPTR(25) = IPTR(25) + 8 - IF (KLOW(K).NE.0) THEN - IPTR(1) = 27 - PRINT *,'NON-ZERO LOWEST ON TEXT DATA' - RETURN - END IF - 1906 CONTINUE -C PRINT *,'TEXT - LOWEST = 0' -C GET NBINC - CALL GBYTE (MSGA,NBINC,IPTR(25),6) - IPTR(25) = IPTR(25) + 6 - IF (NBINC.NE.IPTR(40)) THEN - IPTR(1) = 28 - PRINT *,'NBINC IS NOT THE NUMBER OF CHARACTERS',NBINC - RETURN - END IF -C PRINT *,'TEXT NBINC =',NBINC -C FOR NUMBER OF OBSERVATIONS - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - ISTART = KPRM - I24 = IPTR(24) - DO 1900 N = 1, IDENT(14) - KPRM = ISTART - IPTR(24) = I24 - NBITS = IPTR(40) * 8 - 1700 CONTINUE -C PRINT *,N,IDENT(14),'KPRM-B=',KPRM,IPTR(24),NBITS - IF (NBITS.GT.MWDBIT) THEN - CALL GBYTE (MSGA,IDATA,IPTR(25),MWDBIT) - IPTR(25) = IPTR(25) + MWDBIT - NBITS = NBITS - MWDBIT - IF (IPTR(37).EQ.0) THEN -C CONVERTS ASCII TO EBCIDIC - CALL W3AI39 (IDATA,LW) - END IF - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(N,KPRM) = IDATA -C PRINT *,'TEXT ',N,KPRM,KDATA(N,KPRM) -C SET FOR NEXT PART - KPRM = KPRM + 1 - IPTR(24) = IPTR(24) + 1 -C PRINT 1701,1,KDATA(N,KPRM),N,KPRM,NBITS,IDATA -C1701 FORMAT (1X,I1,1X,6HKDATA=,A4,2X,I5,2X,I5,2X,I5,2X,I12) - GO TO 1700 - ELSE IF (NBITS.GT.0) THEN - CALL GBYTE (MSGA,IDATA,IPTR(25),NBITS) - IPTR(25) = IPTR(25) + NBITS - IBUF = (IPTR(44) - NBITS) / 8 - IF (IBUF.GT.0) THEN - DO 1750 MP = 1, IBUF - IDATA = IDATA * 256 + 32 - 1750 CONTINUE - END IF -C CONVERTS ASCII TO EBCIDIC - IF (IPTR(37).EQ.0) THEN - CALL W3AI39 (IDATA,LW) - END IF - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(N,KPRM) = IDATA -C PRINT *,'TEXT ',N,KPRM,KDATA(N,KPRM) -C PRINT 1701,2,KDATA(N,KPRM),N,KPRM,NBITS - NBITS = 0 - END IF -C WRITE (6,1800)N,(KDATA(N,I),I=KPRS,KPRM) -C1800 FORMAT (2X,I4,2X,3A4) - 1900 CONTINUE - END IF - RETURN - END -C ----------------------------------------------------- - SUBROUTINE FI8804(IPTR,MSGA,KDATA,IVALS,MSTACK, - * IWIDE1,IRFVL1,ISCAL1,J,LL,JDESC,MAXR,MAXD) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8804 PROCESS SERIAL DATA -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 88-09-01 -C -C ABSTRACT: PROCESS DATA THAT IS NOT COMPRESSED -C -C PROGRAM HISTORY LOG: -C 88-09-01 CAVANAUGH -C 91-01-18 CAVANAUGH MODIFIED TO PROPERLY HANDLE NON-COMPRESSED -C DATA. -C 91-04-04 CAVANAUGH TEXT HANDLING PORTION OF THIS ROUTINE -C MODIFIED TO HANDLE FIELD WIDTH IN BYTES. -C 91-04-17 CAVANAUGH TESTS SHOWED THAT THE SAME DATA IN COMPRESSED -C AND UNCOMPRESSED FORM GAVE DIFFERENT RESULTS. -C THIS HAS BEEN CORRECTED. -C -C USAGE: CALL FI8804(IPTR,MSGA,KDATA,IVALS,MSTACK, -C IWIDE1,IRFVL1,ISCAL1,J,LL,JDESC,MAXR,MAXD) -C INPUT ARGUMENT LIST: -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C MSGA - ARRAY CONTAINING BUFR MESSAGE -C IVALS - ARRAY OF SINGLE PARAMETER VALUES -C J - -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C IVALS - SEE ABOVE -C J - SEE ABOVE -C ARRAYS CONTAINING DATA FROM TABLE B -C ISCAL1 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL1 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE1 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - GBYTE -C -C REMARKS: ERROR RETURN: -C IPTR(1) = 13 - BIT WIDTH ON ASCII CHARS NOT A MULTIPLE OF 8 -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C .................................................. -C -C NEW BASE TABLE B -C MAY BE A COMBINATION OF MASTER TABLE B -C AND ANCILLARY TABLE B -C -C INTEGER KFXY1(*) - INTEGER ISCAL1(*) - INTEGER IRFVL1(3,*) - INTEGER IWIDE1(*) -C CHARACTER*40 ANAME1(*) -C CHARACTER*24 AUNIT1(*) -C .................................................. -C - INTEGER MSGA(*),MAXD,MAXR - INTEGER IPTR(*) - INTEGER JDESC - INTEGER IVALS(*) -C INTEGER LSTBLK(3) - INTEGER KDATA(MAXR,MAXD),MSTACK(2,MAXD) - INTEGER J,LL -C LOGICAL LKEY -C -C - INTEGER ITEST(32) -C - SAVE -C - DATA ITEST /1,3,7,15,31,63,127,255, - * 511,1023,2047,4095,8191,16383, - * 32767, 65535,131071,262143,524287, - * 1048575,2097151,4194303,8388607, - * 16777215,33554431,67108863,134217727, - * 268435455,536870911,1073741823, - * 2147483647,-1/ -C - MWDBIT = IPTR(44) - IF (IPTR(45).NE.4) THEN - I = 2147483647 - ITEST(32) = I + I + 1 - END IF -C -C PRINT *,' FI8804 NOCMP',J,JDESC,IWIDE1(J),IPTR(26),IPTR(25) -C -------- NOCMP -------- -C IF NOT TEXT EVENT, PROCESS - IF (IPTR(18).EQ.0) THEN -C PRINT *,' NOT TEXT' - IF ((IPTR(26)+IWIDE1(J)).LT.1) THEN -C PRINT *,' FI8804 NOCMP',J,JDESC,IWIDE1(J),IPTR(26),IPTR(25) - IPTR(1) = 501 - RETURN - END IF -C ISOLATE BIT WIDTH - JWIDE = IWIDE1(J) + IPTR(26) -C IF ASSOCIATED FIELD SW ON - IF (IPTR(29).GT.0) THEN - IF (JDESC.NE.7957.AND.JDESC.NE.7937) THEN - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - MSTACK(1,KPRM) = 33792 + IPTR(29) - MSTACK(2,KPRM) = 0 - CALL GBYTE (MSGA,IVALS,IPTR(25),IPTR(29)) - IPTR(25) = IPTR(25) + IPTR(29) - KDATA(IPTR(17),KPRM) = IVALS(1) -C PRINT *,'FI8804-A',KPRM,MSTACK(1,KPRM), -C * MSTACK(2,KPRM),IPTR(17),KDATA(IPTR(17),KPRM) - END IF - END IF - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - MSTACK(1,KPRM) = JDESC -C IF (IPTR(27).NE.0) THEN -C MSTACK(2,KPRM) = IPTR(27) -C ELSE - MSTACK(2,KPRM) = ISCAL1(J) + IPTR(27) -C END IF -C GET VALUES -C CALL TO GET DATA OF GIVEN BIT WIDTH - CALL GBYTE (MSGA,IVALS,IPTR(25),JWIDE) -C PRINT *,'DATA TO',IPTR(17),KPRM,IVALS(1),JWIDE,IPTR(25) - IPTR(25) = IPTR(25) + JWIDE -C RETURN WITH SINGLE VALUE - IF (IRFVL1(2,J).EQ.0) THEN - JRV = IRFVL1(1,J) - ELSE - JRV = IRFVL1(3,J) - END IF - IF (JWIDE.EQ.32) THEN - IF (IVALS(1).EQ.ITEST(JWIDE)) THEN - KDATA(IPTR(17),KPRM) = 999999 - ELSE - KDATA(IPTR(17),KPRM) = IVALS(1) + JRV - END IF - ELSE IF (IVALS(1).GE.ITEST(JWIDE)) THEN - KDATA(IPTR(17),KPRM) = 999999 - ELSE - KDATA(IPTR(17),KPRM) = IVALS(1) + JRV - END IF -C PRINT *,'FI8804-B',KPRM,MSTACK(1,KPRM), -C * MSTACK(2,KPRM),IPTR(17),KDATA(IPTR(17),KPRM) -C IF(JDESC.EQ.2049) THEN -C PRINT *,'VERT SIG =',KDATA(IPTR(17),KPRM) -C END IF -C PRINT *,'FI8804 ',KPRM,MSTACK(1,KPRM), -C * MSTACK(2,KPRM),KDATA(IPTR(17),KPRM) - ELSE -C PRINT *,' TEXT' -C PRINT *,' FOUND TEXT MODE ****** NOT COMPRESSED *********' - JWIDE = IPTR(40) * 8 -C PRINT *,' WIDTH =',JWIDE,IPTR(40) - NRCHRS = IPTR(40) - NRBITS = JWIDE -C PRINT *,' CHARS =',NRCHRS,' BITS =',NRBITS - IPTR(31) = IPTR(31) + 1 - KANY = 0 - 1800 CONTINUE - KANY = KANY + 1 -C PRINT *,' NR BITS THIS PASS',NRBITS - IF (NRBITS.GT.MWDBIT) THEN - CALL GBYTE (MSGA,IDATA,IPTR(25),MWDBIT) -C PRINT 1801,KANY,IDATA,IPTR(17),KPRM,NRBITS - 1801 FORMAT (1X,I2,4X,Z8,2(4X,I4)) -C CONVERTS ASCII TO EBCIDIC -C COMMENT OUT IF NOT IBM370 COMPUTER - IF (IPTR(37).EQ.0) THEN - CALL W3AI39 (IDATA,IPTR(45)) - END IF - KPRM = IPTR(31) + IPTR(24) - KDATA(IPTR(17),KPRM) = IDATA - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 -C PRINT *,'BODY ',KPRM,MSTACK(1,KPRM),MSTACK(2,KPRM), -C * KDATA(IPTR(17),KPRM) - IPTR(25) = IPTR(25) + MWDBIT - NRBITS = NRBITS - MWDBIT - IPTR(24) = IPTR(24) + 1 - GO TO 1800 - ELSE IF (NRBITS.GT.0) THEN - CALL GBYTE (MSGA,IDATA,IPTR(25),NRBITS) - IPTR(25) = IPTR(25) + NRBITS -C CONVERTS ASCII TO EBCIDIC -C COMMENT OUT IF NOT IBM370 COMPUTER - IF (IPTR(37).EQ.0) THEN - CALL W3AI39 (IDATA,IPTR(45)) - END IF - KPRM = IPTR(31) + IPTR(24) - KSHFT = MWDBIT - NRBITS - IF (KSHFT.GT.0) THEN - KTRY = KSHFT / 8 - DO 1722 LAK = 1, KTRY - IF (IPTR(37).EQ.0) THEN - IDATA = IDATA * 256 + 64 - ELSE - IDATA = IDATA * 256 + 32 - END IF -C PRINT 1723,IDATA -C1723 FORMAT (12X,Z8) - 1722 CONTINUE - END IF - KDATA(IPTR(17),KPRM) = IDATA -C PRINT 1801,KANY,IDATA,KDATA(IPTR(17),KPRM),KPRM - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 -C PRINT *,'TAIL ',KPRM,MSTACK(1,KPRM), -C * KDATA(IPTR(17),KPRM) - END IF - END IF - RETURN - END -C ----------------------------------------------------- - SUBROUTINE FI8805(IPTR,IDENT,MSGA,IWORK,LX,LY, - * KDATA,LL,KNR,MSTACK,MAXR,MAXD) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8805 PROCESS A REPLICATION DESCRIPTOR -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 88-09-01 -C -C ABSTRACT: PROCESS A REPLICATION DESCRIPTOR, MUST EXTRACT NUMBER -C OF REPLICATIONS OF N DESCRIPTORS FROM THE DATA STREAM. -C -C PROGRAM HISTORY LOG: -C 88-09-01 CAVANAUGH -C YY-MM-DD MODIFIER2 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8805(IPTR,IDENT,MSGA,IWORK,LX,LY, -C * KDATA,LL,KNR,MSTACK,MAXR,MAXD) -C INPUT ARGUMENT LIST: -C IWORK - WORKING DESCRIPTOR LIST -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C IDENT - SEE W3FI88 ROUTINE DOCBLOCK -C LX - X PORTION OF CURRENT DESCRIPTOR -C LY - Y PORTION OF CURRENT DESCRIPTOR -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C LX - SEE ABOVE -C LY - SEE ABOVE -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - GBYTES FI8808 -C -C REMARKS: ERROR RETURN: -C IPTR(1) = 12 DATA DESCRIPTOR QUALIFIER DOES NOT FOLLOW -C DELAYED REPLICATION DESCRIPTOR -C = 20 EXCEEDED COUNT FOR DELAYED REPLICATION PASS -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C - INTEGER IPTR(*) - INTEGER KNR(MAXR) - INTEGER ITEMP(2000) - INTEGER LL - INTEGER KTEMP(2000) - INTEGER KDATA(MAXR,MAXD) - INTEGER LX,MSTACK(2,MAXD) - INTEGER LY - INTEGER MSGA(*) - INTEGER KVALS(1300) -CVVVVVCHANGE#2 FIX BY KEYSER -- 12/06/1994 -C NOTE: THIS FIX JUST CLEANS UP CODE SINCE IWORK ARRAY IS EARLIER -C DEFINED AS 15000 WORDS - INTEGER IWORK(*) -CDAK INTEGER IWORK(MAXD) -CAAAAACHANGE#2 FIX BY KEYSER -- 12/06/1994 - INTEGER IDENT(*) -C - SAVE -C -C PRINT *,' REPLICATION FI8805' -C DO 7100 I = 1, IPTR(13) -C PRINT *,I,IWORK(I) -C7100 CONTINUE -C NUMBER OF DESCRIPTORS - NRSET = LX -C NUMBER OF REPLICATIONS - NRREPS = LY - ICURR = IPTR(11) - 1 - IPICK = IPTR(11) - 1 -C - IF (NRREPS.EQ.0) THEN - IPTR(39) = 1 -C SAVE PRIMARY DELAYED REPLICATION DESCRIPTOR -C IPTR(31) = IPTR(31) + 1 -C KPRM = IPTR(31) + IPTR(24) -C MSTACK(1,KPRM) = JDESC -C MSTACK(2,KPRM) = 0 -C KDATA(IPTR(17),KPRM) = 0 -C PRINT *,'FI8805-1',KPRM,MSTACK(1,KPRM), -C * MSTACK(2,KPRM),KDATA(IPTR(17),KPRM) -C DELAYED REPLICATION - MUST GET NUMBER OF -C REPLICATIONS FROM DATA. -C GET NEXT DESCRIPTOR - CALL FI8808(IPTR,IWORK,LF,LX,LY,JDESC) -C PRINT *,' DELAYED REPLICATION',LF,LX,LY,JDESC -C MUST BE DATA DESCRIPTION -C OPERATION QUALIFIER - IF (JDESC.EQ.7937.OR.JDESC.EQ.7947) THEN - JWIDE = 8 - ELSE IF (JDESC.EQ.7938.OR.JDESC.EQ.7948) THEN - JWIDE = 16 - ELSE IF (JDESC.EQ.7936) THEN - JWIDE = 1 - ELSE - IPTR(1) = 12 - RETURN - END IF -C THIS IF BLOCK IS SET TO HANDLE -C DATA/DESCRIPTOR REPLICATION - IF (JDESC.EQ.7947.OR.JDESC.EQ.7948) THEN -C SET DATA/DESCRIPTOR REPLICATION FLAG = ON - IPTR(38) = 1 -C SAVE AS NEXT ENTRY IN KDATA, MSTACK - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - CALL GBYTE (MSGA,KVALS,IPTR(25),JWIDE) - IPTR(25) = IPTR(25) + JWIDE - KDATA(IPTR(17),KPRM) = KVALS(1) - RETURN - END IF - -C SET SINGLE VALUE FOR SEQUENTIAL, -C MULTIPLE VALUES FOR COMPRESSED - IF (IDENT(16).EQ.0) THEN - -C NON COMPRESSED - CALL GBYTE (MSGA,KVALS,IPTR(25),JWIDE) -C PRINT *,LF,LX,LY,JDESC,' NR OF REPLICATIONS',KVALS(1) - IPTR(25) = IPTR(25) + JWIDE - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(IPTR(17),KPRM) = KVALS(1) - NRREPS = KVALS(1) -C PRINT *,'FI8805-2',KPRM,MSTACK(1,KPRM), -C * MSTACK(2,KPRM),KDATA(IPTR(17),KPRM) - ELSE - NRVALS = IDENT(14) - CALL GBYTES (MSGA,KVALS,IPTR(25),JWIDE,0,NRVALS) - IPTR(25) = IPTR(25) + JWIDE * NRVALS - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(IPTR(17),KPRM) = KVALS(1) - DO 100 I = 1, NRVALS - KDATA(I,KPRM) = KVALS(I) - 100 CONTINUE - NRREPS = KVALS(1) - END IF - ELSE -C PRINT *,'NOT DELAYED REPLICATION' - END IF -C RESTRUCTURE WORKING STACK W/REPLICATIONS - IF (NRREPS.EQ.0) THEN -C PRINT *,'RESTRUCTURING - NO REPLICATION' - IPTR(11) = IPICK + NRSET + 2 - GO TO 9999 - END IF -C PRINT *,' SAVE OFF',NRSET,' DESCRIPTORS' -C PICK UP DESCRIPTORS TO BE REPLICATED - DO 1000 I = 1, NRSET - CALL FI8808(IPTR,IWORK,LF,LX,LY,JDESC) - ITEMP(I) = JDESC -C PRINT *,'REPLICATION ',I,ITEMP(I) - 1000 CONTINUE -C MOVE TRAILING DESCRIPTORS TO HOLD AREA - LAX = IPTR(12) - IPTR(11) + 1 -C PRINT *,LAX,' TRAILING DESCRIPTORS TO HOLD AREA',IPTR(11),IPTR(12) - DO 2000 I = 1, LAX - CALL FI8808(IPTR,IWORK,LF,LX,LY,JDESC) - KTEMP(I) = JDESC -C PRINT *,' ',I,KTEMP(I) - 2000 CONTINUE -C REPLICATIONS INTO ISTACK -C PRINT *,' MUST REPLICATE ',KX,' DESCRIPTORS',KY,' TIMES' -C PRINT *,'REPLICATIONS INTO STACK. LOC',ICURR - DO 4000 I = 1, NRREPS - DO 3000 J = 1, NRSET - IWORK(ICURR) = ITEMP(J) -C PRINT *,'FI8805 A',ICURR,IWORK(ICURR) - ICURR = ICURR + 1 - 3000 CONTINUE - 4000 CONTINUE -C PRINT *,' TO LOC',ICURR-1 -C RESTORE TRAILING DESCRIPTORS -C PRINT *,'TRAILING DESCRIPTORS INTO STACK. LOC',ICURR - DO 5000 I = 1, LAX - IWORK(ICURR) = KTEMP(I) -C PRINT *,'FI8805 B',ICURR,IWORK(ICURR) - ICURR = ICURR + 1 - 5000 CONTINUE - IPTR(12) = ICURR - 1 - IPTR(11) = IPICK - 9999 CONTINUE -C DO 5500 I = 1, IPTR(12) -C PRINT *,'FI8805 B',I,IWORK(I),IPTR(11) -C5500 CONTINUE - RETURN - END - SUBROUTINE FI8806 (IPTR,LX,LY,IDENT,MSGA,KDATA,IVALS,MSTACK, - * IWIDE1,IRFVL1,ISCAL1,J,LL,KFXY1,IWORK,JDESC,MAXR,MAXD,KPTRB) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8806 PROCESS OPERATOR DESCRIPTORS -C PRGMMR: CAVANAUGH ORG: W/NMCX42 DATE: 88-09-01 -C -C ABSTRACT: EXTRACT AND SAVE INDICATED CHANGE VALUES FOR USE -C UNTIL CHANGES ARE RESCINDED, OR EXTRACT TEXT STRINGS INDICATED -C THROUGH 2 05 YYY. -C -C PROGRAM HISTORY LOG: -C 88-09-01 CAVANAUGH -C 91-04-04 CAVANAUGH MODIFIED TO HANDLE DESCRIPTOR 2 05 YYY -C 91-05-10 CAVANAUGH CODING HAS BEEN ADDED TO PROCESS PROPERLY -C TABLE C DESCRIPTOR 2 06 YYY. -C 91-11-21 CAVANAUGH CODING HAS BEEN ADDED TO PROPERLY PROCESS -C TABLE C DESCRIPTOR 2 03 YYY, THE CHANGE -C TO NEW REFERENCE VALUE FOR SELECTED -C DESCRIPTORS. -C -C USAGE: CALL FI8806 (IPTR,LX,LY,IDENT,MSGA,KDATA,IVALS,MSTACK, -C * IWIDE1,IRFVL1,ISCAL1,J,LL,KFXY1,IWORK,JDESC,MAXR,MAXD,KPTRB) -C INPUT ARGUMENT LIST: -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C LX - X PORTION OF CURRENT DESCRIPTOR -C LY - Y PORTION OF CURRENT DESCRIPTOR -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C -C OUTPUT ARGUMENT LIST: -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C ARRAYS CONTAINING DATA FROM TABLE B -C ISCAL1 - SCALE FOR VALUE OF DESCRIPTOR -C IRFVL1 - REFERENCE VALUE FOR DESCRIPTOR -C IWIDE1 - BIT WIDTH FOR VALUE OF DESCRIPTOR -C -C REMARKS: ERROR RETURN: -C IPTR(1) = 5 - ERRONEOUS X VALUE IN DATA DESCRIPTOR OPERATOR -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C .................................................. -C -C NEW BASE TABLE B -C MAY BE A COMBINATION OF MASTER TABLE B -C AND ANCILLARY TABLE B -C - INTEGER KFXY1(*),ISCAL1(*),IRFVL1(3,*),IWIDE1(*) -C CHARACTER*40 ANAME1(*) -C CHARACTER*24 AUNIT1(*) -C .................................................. - INTEGER IPTR(*),KDATA(MAXR,MAXD),IVALS(*) - INTEGER IDENT(*),IWORK(*),KPTRB(*) - INTEGER MSGA(*),MSTACK(2,MAXD) - INTEGER J,JDESC - INTEGER LL - INTEGER LX - INTEGER LY -C - SAVE -C -C PRINT *,' F2 - DATA DESCRIPTOR OPERATOR' - IF (LX.EQ.1) THEN -C CHANGE BIT WIDTH - IF (LY.EQ.0) THEN -C PRINT *,' RETURN TO NORMAL WIDTH' - IPTR(26) = 0 - ELSE -C PRINT *,' EXPAND WIDTH BY',LY-128,' BITS' - IPTR(26) = LY - 128 - END IF - ELSE IF (LX.EQ.2) THEN -C CHANGE SCALE - IF (LY.EQ.0) THEN -C RESET TO STANDARD SCALE - IPTR(27) = 0 - ELSE -C SET NEW SCALE - IPTR(27) = LY - 128 - END IF - ELSE IF (LX.EQ.3) THEN -C CHANGE REFERENCE VALUE -C FOR EACH OF THOSE DESCRIPTORS BETWEEN -C 2 03 YYY WHERE Y LT 255 AND -C 2 03 255, EXTRACT THE NEW REFERENCE -C VALUE (BIT WIDTH YYY) AND PLACE -C IN TERTIARY TABLE B REF VAL POSITION, -C SET FLAG IN SECONDARY REFVAL POSITION -C THOSE DESCRIPTORS DO NOT HAVE DATA -C ASSOCIATED WITH THEM, BUT ONLY -C IDENTIFY THE TABLE B ENTRIES THAT -C ARE GETTING NEW REFERENCE VALUES. - KYYY = LY - IF (KYYY.GT.0.AND.KYYY.LT.255) THEN -C START CYCLING THRU DESCRIPTORS UNTIL -C TERMINATE NEW REF VALS IS FOUND - 300 CONTINUE - CALL FI8808 (IPTR,IWORK,LF,LX,LY,JDESC) - IF (JDESC.EQ.33791) THEN -C IF 2 03 255 THEN RETURN - RETURN - END IF -C FIND MATCHING TABLE B ENTRY - LJ = KPTRB(JDESC) - IF (LJ.LT.1) THEN -C MATCHING DESCRIPTOR NOT FOUND, ERROR ERROR - PRINT *,'2 03 YYY - MATCHING DESCRIPTOR NOT FOUND' - IPTR(1) = 23 - RETURN - END IF -C TURN ON SWITCH - IRFVL1(2,LJ) = 1 -C INSERT NEW REFERENCE VALUE - CALL GBYTE (MSGA,IRFVL1(3,LJ),IPTR(25),KYYY) - GO TO 300 - ELSE IF (KYYY.EQ.0) THEN -C MUST TURN OFF ALL NEW -C REFERENCE VALUES - DO 400 I = 1, IPTR(21) - IRFVL1(2,I) = 0 - 400 CONTINUE - END IF -C LX = 3 -C MUST BE CONCLUDED WITH Y=255 - ELSE IF (LX.EQ.4) THEN -C ASSOCIATED VALUES - IF (LY.EQ.0) THEN - IPTR(29) = 0 -C PRINT *,'RESET ASSOCIATED VALUES',IPTR(29) - ELSE - IPTR(29) = LY - IF (IWORK(IPTR(11)).NE.7957) THEN - PRINT *,'2 04 YYY NOT FOLLOWED BY 0 31 021' - IPTR(1) = 11 - END IF -C PRINT *,'SET ASSOCIATED VALUES',IPTR(29) - END IF - ELSE IF (LX.EQ.5) THEN - MWDBIT = IPTR(44) -C PROCESS TEXT DATA - IPTR(40) = LY - IPTR(18) = 1 - J = KPTRB(JDESC) - IF (IDENT(16).EQ.0) THEN -C PRINT *,'FROM FI8806 - 2 05 YYY - NONCOMPRESSED TEXT',J - CALL FI8804(IPTR,MSGA,KDATA,IVALS,MSTACK, - * IWIDE1,IRFVL1,ISCAL1,J,LL,JDESC,MAXR,MAXD) - ELSE -C PRINT *,'2 05 YYY - TEXT - COMPRESSED MODE YYY=',LY -C PRINT *,'TEXT - LOWEST = 0' - IPTR(25) = IPTR(25) + IPTR(40) * 8 -C GET NBINC -C CALL GBYTE (MSGA,NBINC,IPTR(25),6) - IPTR(25) = IPTR(25) + 6 - NBINC = IPTR(40) -C PRINT *,'TEXT NBINC =',NBINC,IPTR(40) -C FOR NUMBER OF OBSERVATIONS - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - ISTART = KPRM - DO 1900 N = 1, IDENT(14) - KPRM = ISTART - NBITS = IPTR(40) * 8 - 1700 CONTINUE -C PRINT *,'1700',KDATA(N,KPRM),N,KPRM,NBITS - IF (NBITS.GT.MWDBIT) THEN - CALL GBYTE (MSGA,IDATA,IPTR(25),MWDBIT) - IPTR(25) = IPTR(25) + MWDBIT - NBITS = NBITS - MWDBIT -C CONVERTS ASCII TO EBCIDIC -C COMMENT OUT IF NOT IBM370 COMPUTER - IF (IPTR(37).EQ.0) THEN - CALL W3AI39 (IDATA,IPTR(45)) - END IF - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(N,KPRM) = IDATA -C PRINT *,'TEXT ',N,KPRM,KDATA(N,KPRM) -C SET FOR NEXT PART - KPRM = KPRM + 1 -C PRINT 1701,1,KDATA(N,KPRM),N,KPRM,NBITS,IDATA -C1701 FORMAT (1X,I1,1X,6HKDATA=,A4,2X,I5,2X,I5,2X,I5,2X, -C * I10) - GO TO 1700 - ELSE IF (NBITS.EQ.MWDBIT) THEN - CALL GBYTE (MSGA,IDATA,IPTR(25),MWDBIT) - IPTR(25) = IPTR(25) + MWDBIT - NBITS = NBITS - MWDBIT -C CONVERTS ASCII TO EBCIDIC -C COMMENT OUT IF NOT IBM370 COMPUTER - IF (IPTR(37).EQ.0) THEN - CALL W3AI39 (IDATA,IPTR(45)) - END IF - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(N,KPRM) = IDATA -C PRINT *,'TEXT ',N,KPRM,KDATA(N,KPRM) -C SET FOR NEXT PART - KPRM = KPRM + 1 -C PRINT 1701,1,KDATA(N,KPRM),N,KPRM,NBITS,IDATA - ELSE IF (NBITS.GT.0) THEN - CALL GBYTE (MSGA,IDATA,IPTR(25),NBITS) - IPTR(25) = IPTR(25) + NBITS - IBUF = (MWDBIT - NBITS) / 8 - IF (IBUF.GT.0) THEN - DO 1750 MP = 1, IBUF - IDATA = IDATA * 256 + 32 - 1750 CONTINUE - END IF -C CONVERTS ASCII TO EBCIDIC -C COMMENT OUT IF NOT IBM370 COMPUTER - IF (IPTR(37).EQ.0) THEN - CALL W3AI39 (IDATA,IPTR(45)) - END IF - MSTACK(1,KPRM) = JDESC - MSTACK(2,KPRM) = 0 - KDATA(N,KPRM) = IDATA -C PRINT *,'TEXT ',N,KPRM,KDATA(N,KPRM) -C PRINT 1701,2,KDATA(N,KPRM),N,KPRM,NBITS - END IF -C WRITE (6,1800)N,(KDATA(N,I),I=KPRS,KPRM) -C1800 FORMAT (2X,I4,2X,3A4) - 1900 CONTINUE - - IPTR(24) = IPTR(24) + IPTR(40) / 4 - 1 - IF (MOD(IPTR(40),4).NE.0) IPTR(24) = IPTR(24) + 1 - END IF - IPTR(18) = 0 -C --------------------------- - ELSE IF (LX.EQ.6) THEN -C SKIP NEXT DESCRIPTOR -C SET TO PASS OVER DESCRIPTOR AND DATA -C IF DESCRIPTOR NOT IN TABLE B - IPTR(36) = LY -C PRINT *,'SET TO SKIP',LY,' BIT FIELD' - IPTR(31) = IPTR(31) + 1 - KPRM = IPTR(31) + IPTR(24) - MSTACK(1,KPRM) = 34304 + LY - MSTACK(2,KPRM) = 0 - ELSE - IPTR(1) = 5 - ENDIF - RETURN - END - SUBROUTINE FI8807(IPTR,IWORK,ITBLD,ITBLD2,JDESC,KPTRD) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8807 PROCESS QUEUE DESCRIPTOR -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 88-09-01 -C -C ABSTRACT: SUBSTITUTE DESCRIPTOR QUEUE FOR QUEUE DESCRIPTOR -C -C PROGRAM HISTORY LOG: -C 88-09-01 CAVANAUGH -C 91-04-17 CAVANAUGH IMPROVED HANDLING OF NESTED QUEUE DESCRIPTORS -C 91-05-28 CAVANAUGH IMPROVED HANDLING OF NESTED QUEUE DESCRIPTORS -C BASED ON TESTS WITH LIVE DATA. -C -C USAGE: CALL FI8807(IPTR,IWORK,ITBLD,ITBLD2,JDESC,KPTRD) -C INPUT ARGUMENT LIST: -C IWORK - WORKING DESCRIPTOR LIST -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C LAST - INDEX TO LAST DESCRIPTOR -C ITBLD - ARRAY CONTAINING DESCRIPTOR QUEUES -C JDESC - QUEUE DESCRIPTOR TO BE EXPANDED -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C ISTACK - SEE ABOVE -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - NONE -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C .................................................. -C -C ANCILLARY TABLE D FROM TYPE 11 BUFR MESSAGE -C - INTEGER ITBLD2(20,*) -C .................................................. -C -C NEW BASE TABLE D -C - INTEGER ITBLD(20,*) -C .................................................. -C - INTEGER IPTR(*),JDESC,KPTRD(*) - INTEGER IWORK(*),IHOLD(15000) -C - SAVE -C PRINT *,' FI8807 F3 ENTRY',IPTR(11),IPTR(12) -C SET FOR BINARY SEARCH IN TABLE D - JLO = 1 - JHI = IPTR(20) -C PRINT *,'LOOKING FOR QUEUE DESCRIPTOR',JDESC,IPTR(11),IPTR(12) -C - JMID = KPTRD(MOD(JDESC,16384)) - IF (JMID.LT.0) THEN - IPTR(1) = 4 - RETURN - END IF -C HAVE TABLE D MATCH -C PRINT *,'D ',(ITBLD(LL,JMID),LL=1,20) -C PRINT *,'TABLE D TO IHOLD' - IK = 0 - JK = 0 - DO 200 KI = 2, 20 - IF (ITBLD(KI,JMID).NE.0) THEN - IK = IK + 1 - IHOLD(IK) = ITBLD(KI,JMID) -C PRINT *,IK,IHOLD(IK) - ELSE - GO TO 300 - END IF - 200 CONTINUE - 300 CONTINUE - KK = IPTR(11) - IF (KK.GT.IPTR(12)) THEN -C NOTHING MORE TO APPEND -C PRINT *,'NOTHING MORE TO APPEND' - ELSE -C APPEND TRAILING IWORK TO IHOLD -C PRINT *,'APPEND FROM ',KK,' TO',IPTR(12) - DO 500 I = KK, IPTR(12) - IK = IK + 1 - IHOLD(IK) = IWORK(I) - 500 CONTINUE - END IF -C RESET IHOLD TO IWORK -C PRINT *,' RESET IWORK STACK' - KK = IPTR(11) - 2 - DO 1000 I = 1, IK - KK = KK + 1 - IWORK(KK) = IHOLD(I) - 1000 CONTINUE - IPTR(12) = KK -C PRINT *,' FI8807 F3 EXIT ',IPTR(11),IPTR(12) -C DO 2000 I = 1, IPTR(12) -C PRINT *,'EXIT IWORK',I,IWORK(I) -C2000 CONTINUE -C RESET POINTERS - IPTR(11) = IPTR(11) - 1 - RETURN - END -C ----------------------------------------------------- - SUBROUTINE FI8808(IPTR,IWORK,LF,LX,LY,JDESC) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8808 -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 89-01-17 -C -C ABSTRACT: -C -C PROGRAM HISTORY LOG: -C 88-09-01 CAVANAUGH -C YY-MM-DD MODIFIER1 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8808(IPTR,IWORK,LF,LX,LY,JDESC) -C INPUT ARGUMENT LIST: -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C IWORK - WORKING DESCRIPTOR LIST -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IPTR - SEE ABOVE -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ - INTEGER IPTR(*),IWORK(*),LF,LX,LY,JDESC - SAVE -C -C PRINT *,' FI8808 NEW DESCRIPTOR PICKUP' - JDESC = IWORK(IPTR(11)) - LY = MOD(JDESC,256) - IPTR(34) = LY - LX = MOD((JDESC/256),64) - IPTR(33) = LX - LF = JDESC / 16384 - IPTR(32) = LF -C PRINT *,' TEST DESCRIPTOR',LF,LX,LY,' AT',IPTR(11) - IPTR(11) = IPTR(11) + 1 - RETURN - END - SUBROUTINE FI8809(IDENT,MSTACK,KDATA,IPTR,MAXR,MAXD) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8809 REFORMAT PROFILER W HGT INCREMENTS -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 90-02-14 -C -C ABSTRACT: REFORMAT DECODED PROFILER DATA TO SHOW HEIGHTS INSTEAD OF -C HEIGHT INCREMENTS. -C -C PROGRAM HISTORY LOG: -C 90-02-14 CAVANAUGH -C -C USAGE: CALL FI8809(IDENT,MSTACK,KDATA,IPTR,MAXR,MAXD) -C INPUT ARGUMENT LIST: -C IDENT - ARRAY CONTAINS MESSAGE INFORMATION EXTRACTED FROM -C BUFR MESSAGE - -C IDENT(1) -EDITION NUMBER (BYTE 4, SECTION 1) -C IDENT(2) -ORIGINATING CENTER (BYTES 5-6, SECTION 1) -C IDENT(3) -UPDATE SEQUENCE (BYTE 7, SECTION 1) -C IDENT(4) - (BYTE 8, SECTION 1) -C IDENT(5) -BUFR MESSAGE TYPE (BYTE 9, SECTION 1) -C IDENT(6) -BUFR MSG SUB-TYPE (BYTE 10, SECTION 1) -C IDENT(7) - (BYTES 11-12, SECTION 1) -C IDENT(8) -YEAR OF CENTURY (BYTE 13, SECTION 1) -C IDENT(9) -MONTH OF YEAR (BYTE 14, SECTION 1) -C IDENT(10)-DAY OF MONTH (BYTE 15, SECTION 1) -C IDENT(11)-HOUR OF DAY (BYTE 16, SECTION 1) -C IDENT(12)-MINUTE OF HOUR (BYTE 17, SECTION 1) -C IDENT(13)-RSVD BY ADP CENTERS(BYTE 18, SECTION 1) -C IDENT(14)-NR OF DATA SUBSETS (BYTE 5-6, SECTION 3) -C IDENT(15)-OBSERVED FLAG (BYTE 7, BIT 1, SECTION 3) -C IDENT(16)-COMPRESSION FLAG (BYTE 7, BIT 2, SECTION 3) -C MSTACK - WORKING DESCRIPTOR LIST AND SCALING FACTOR -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C KSET2 - INTERIM DATA ARRAY -C KPROFL - INTERIM DESCRIPTOR ARRAY -C IPTR - SEE W3FI88 -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C -C OUTPUT FILES: -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C ---------------------------------------------------------------- -C - INTEGER ISW - INTEGER IDENT(*),KDATA(MAXR,MAXD) - INTEGER MSTACK(2,MAXD),IPTR(*) - INTEGER KPROFL(1700) - INTEGER KPROF2(1700) - INTEGER KSET2(1700) -C -C ---------------------------------------------------------- - SAVE -C PRINT *,'FI8809' -C LOOP FOR NUMBER OF SUBSETS/REPORTS - DO 3000 I = 1, IDENT(14) -C INIT FOR DATA INPUT ARRAY - MK = 1 -C INIT FOR DESC OUTPUT ARRAY - JK = 0 -C LOCATION - ISW = 0 - DO 200 J = 1, 3 -C LATITUDE - IF (MSTACK(1,MK).EQ.1282) THEN - ISW = ISW + 1 - GO TO 100 -C LONGITUDE - ELSE IF (MSTACK(1,MK).EQ.1538) THEN - ISW = ISW + 2 - GO TO 100 -C HEIGHT ABOVE SEA LEVEL - ELSE IF (MSTACK(1,MK).EQ.1793) THEN - IHGT = KDATA(I,MK) - ISW = ISW + 4 - GO TO 100 - END IF - GO TO 200 - 100 CONTINUE - JK = JK + 1 -C SAVE DESCRIPTOR - KPROFL(JK) = MSTACK(1,MK) -C SAVE SCALE - KPROF2(JK) = MSTACK(2,MK) -C SAVE DATA - KSET2(JK) = KDATA(I,MK) - MK = MK + 1 - 200 CONTINUE - IF (ISW.NE.7) THEN - PRINT *,'LOCATION ERROR PROCESSING PROFILER' - IPTR(1) = 200 - RETURN - END IF -C TIME - ISW = 0 - DO 400 J = 1, 7 -C YEAR - IF (MSTACK(1,MK).EQ.1025) THEN - ISW = ISW + 1 - GO TO 300 -C MONTH - ELSE IF (MSTACK(1,MK).EQ.1026) THEN - ISW = ISW + 2 - GO TO 300 -C DAY - ELSE IF (MSTACK(1,MK).EQ.1027) THEN - ISW = ISW + 4 - GO TO 300 -C HOUR - ELSE IF (MSTACK(1,MK).EQ.1028) THEN - ISW = ISW + 8 - GO TO 300 -C MINUTE - ELSE IF (MSTACK(1,MK).EQ.1029) THEN - ISW = ISW + 16 - GO TO 300 -C TIME SIGNIFICANCE - ELSE IF (MSTACK(1,MK).EQ.2069) THEN - ISW = ISW + 32 - GO TO 300 - ELSE IF (MSTACK(1,MK).EQ.1049) THEN - ISW = ISW + 64 - GO TO 300 - END IF - GO TO 400 - 300 CONTINUE - JK = JK + 1 -C SAVE DESCRIPTOR - KPROFL(JK) = MSTACK(1,MK) -C SAVE SCALE - KPROF2(JK) = MSTACK(2,MK) -C SAVE DATA - KSET2(JK) = KDATA(I,MK) - MK = MK + 1 - 400 CONTINUE - IF (ISW.NE.127) THEN - PRINT *,'TIME ERROR PROCESSING PROFILER',ISW - IPTR(1) = 201 - RETURN - END IF -C SURFACE DATA - KRG = 0 - ISW = 0 - DO 600 J = 1, 10 -C WIND SPEED - IF (MSTACK(1,MK).EQ.2818) THEN - ISW = ISW + 1 - GO TO 500 -C WIND DIRECTION - ELSE IF (MSTACK(1,MK).EQ.2817) THEN - ISW = ISW + 2 - GO TO 500 -C PRESS REDUCED TO MSL - ELSE IF (MSTACK(1,MK).EQ.2611) THEN - ISW = ISW + 4 - GO TO 500 -C TEMPERATURE - ELSE IF (MSTACK(1,MK).EQ.3073) THEN - ISW = ISW + 8 - GO TO 500 -C RAINFALL RATE - ELSE IF (MSTACK(1,MK).EQ.3342) THEN - ISW = ISW + 16 - GO TO 500 -C RELATIVE HUMIDITY - ELSE IF (MSTACK(1,MK).EQ.3331) THEN - ISW = ISW + 32 - GO TO 500 -C 1ST RANGE GATE OFFSET - ELSE IF (MSTACK(1,MK).EQ.1982.OR. - * MSTACK(1,MK).EQ.1983) THEN -C CANNOT USE NORMAL PROCESSING FOR FIRST RANGE GATE, MUST SAVE -C VALUE FOR LATER USE - IF (MSTACK(1,MK).EQ.1983) THEN - IHGT = KDATA(I,MK) - MK = MK + 1 - KRG = 1 - ELSE - IF (KRG.EQ.0) THEN - INCRHT = KDATA(I,MK) - MK = MK + 1 - KRG = 1 -C PRINT *,'INITIAL INCR =',INCRHT - ELSE - LHGT = 500 + IHGT - KDATA(I,MK) - ISW = ISW + 64 -C PRINT *,'BASE HEIGHT=',LHGT,' INCR=',INCRHT - END IF - END IF -C MODE #1 - ELSE IF (MSTACK(1,MK).EQ.8128) THEN - ISW = ISW + 128 - GO TO 500 -C MODE #2 - ELSE IF (MSTACK(1,MK).EQ.8129) THEN - ISW = ISW + 256 - GO TO 500 - END IF - GO TO 600 - 500 CONTINUE -C SAVE DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = MSTACK(1,MK) -C SAVE SCALE - KPROF2(JK) = MSTACK(2,MK) -C SAVE DATA - KSET2(JK) = KDATA(I,MK) -C IF (I.EQ.1) THEN -C PRINT *,' ',JK,KPROFL(JK),KSET2(JK) -C END IF - MK = MK + 1 - 600 CONTINUE - IF (ISW.NE.511) THEN - PRINT *,'SURFACE ERROR PROCESSING PROFILER',ISW - IPTR(1) = 202 - RETURN - END IF -C 43 LEVELS - DO 2000 L = 1, 43 - 2020 CONTINUE - ISW = 0 -C HEIGHT INCREMENT - IF (MSTACK(1,MK).EQ.1982) THEN -C PRINT *,'NEW HEIGHT INCREMENT',KDATA(I,MK) - INCRHT = KDATA(I,MK) - MK = MK + 1 - IF (LHGT.LT.(9250+IHGT)) THEN - LHGT = IHGT + 500 - INCRHT - ELSE - LHGT = IHGT + 9250 - INCRHT - END IF - END IF -C MUST ENTER HEIGHT OF THIS LEVEL - DESCRIPTOR AND DATA -C AT THIS POINT - HEIGHT + INCREMENT + BASE VALUE - LHGT = LHGT + INCRHT -C PRINT *,'LEVEL ',L,LHGT - IF (L.EQ.37) THEN - LHGT = LHGT + INCRHT - END IF - JK = JK + 1 -C SAVE DESCRIPTOR - KPROFL(JK) = 1798 -C SAVE SCALE - KPROF2(JK) = 0 -C SAVE DATA - KSET2(JK) = LHGT -C IF (I.EQ.10) THEN -C PRINT *,' ' -C PRINT *,'HGT',JK,KPROFL(JK),KSET2(JK) -C END IF - ISW = 0 - DO 800 J = 1, 9 - 750 CONTINUE - IF (MSTACK(1,MK).EQ.1982) THEN - GO TO 2020 -C U VECTOR VALUE - ELSE IF (MSTACK(1,MK).EQ.3008) THEN - ISW = ISW + 1 - IF (KDATA(I,MK).GE.2047) THEN - VECTU = 32767 - ELSE - VECTU = KDATA(I,MK) - END IF - MK = MK + 1 - GO TO 800 -C V VECTOR VALUE - ELSE IF (MSTACK(1,MK).EQ.3009) THEN - ISW = ISW + 2 - IF (KDATA(I,MK).GE.2047) THEN - VECTV = 32767 - ELSE - VECTV = KDATA(I,MK) - END IF - MK = MK + 1 -C IF U VALUE IS ALSO AVAILABLE THEN GENERATE DDFFF -C DESCRIPTORS AND DATA - IF (IAND(ISW,1).NE.0) THEN - IF (VECTU.EQ.32767.OR.VECTV.EQ.32767) THEN -C SAVE DD DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = 2817 -C SAVE SCALE - KPROF2(JK) = 0 -C SAVE DD DATA - KSET2(JK) = 32767 -C SAVE FFF DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = 2818 -C SAVE SCALE - KPROF2(JK) = 1 -C SAVE FFF DATA - KSET2(JK) = 32767 - ELSE -C GENERATE DDFFF - CALL W3FC05 (VECTU,VECTV,DIR,SPD) - NDIR = DIR - SPD = SPD - NSPD = SPD -C PRINT *,' ',NDIR,NSPD -C SAVE DD DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = 2817 -C SAVE SCALE - KPROF2(JK) = 0 -C SAVE DD DATA - KSET2(JK) = DIR -C IF (I.EQ.1) THEN -C PRINT *,'DD ',JK,KPROFL(JK),KSET2(JK) -C END IF -C SAVE FFF DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = 2818 -C SAVE SCALE - KPROF2(JK) = 1 -C SAVE FFF DATA - KSET2(JK) = SPD -C IF (I.EQ.1) THEN -C PRINT *,'FFF',JK,KPROFL(JK),KSET2(JK) -C END IF - END IF - END IF - GO TO 800 -C W VECTOR VALUE - ELSE IF (MSTACK(1,MK).EQ.3010) THEN - ISW = ISW + 4 - GO TO 700 -C Q/C TEST RESULTS - ELSE IF (MSTACK(1,MK).EQ.8130) THEN - ISW = ISW + 8 - GO TO 700 -C U,V QUALITY IND - ELSE IF(IAND(ISW,16).EQ.0.AND.MSTACK(1,MK).EQ.2070) THEN - ISW = ISW + 16 - GO TO 700 -C W QUALITY IND - ELSE IF(IAND(ISW,32).EQ.0.AND.MSTACK(1,MK).EQ.2070) THEN - ISW = ISW + 32 - GO TO 700 -C SPECTRAL PEAK POWER - ELSE IF (MSTACK(1,MK).EQ.5568) THEN - ISW = ISW + 64 - GO TO 700 -C U,V VARIABILITY - ELSE IF (MSTACK(1,MK).EQ.3011) THEN - ISW = ISW + 128 - GO TO 700 -C W VARIABILITY - ELSE IF (MSTACK(1,MK).EQ.3013) THEN - ISW = ISW + 256 - GO TO 700 - ELSE IF ((MSTACK(1,MK)/16384).NE.0) THEN - MK = MK + 1 - GO TO 750 - END IF - GO TO 800 - 700 CONTINUE - JK = JK + 1 -C SAVE DESCRIPTOR - KPROFL(JK) = MSTACK(1,MK) -C SAVE SCALE - KPROF2(JK) = MSTACK(2,MK) -C SAVE DATA - KSET2(JK) = KDATA(I,MK) - MK = MK + 1 -C IF (I.EQ.1) THEN -C PRINT *,' ',JK,KPROFL(JK),KSET2(JK) -C END IF - 800 CONTINUE - IF (ISW.NE.511) THEN - PRINT *,'LEVEL ERROR PROCESSING PROFILER',ISW - IPTR(1) = 203 - RETURN - END IF - 2000 CONTINUE -C MOVE DATA BACK INTO KDATA ARRAY - DO 4000 LL = 1, JK - KDATA(I,LL) = KSET2(LL) - 4000 CONTINUE - 3000 CONTINUE -C PRINT *,'REBUILT ARRAY' - DO 5000 LL = 1, JK -C DESCRIPTOR - MSTACK(1,LL) = KPROFL(LL) -C SCALE - MSTACK(2,LL) = KPROF2(LL) -C PRINT *,LL,MSTACK(1,LL),(KDATA(I,LL),I=1,7) - 5000 CONTINUE -C MOVE REFORMATTED DESCRIPTORS TO MSTACK ARRAY - IPTR(31) = JK - RETURN - END - SUBROUTINE FI8810(IDENT,MSTACK,KDATA,IPTR,MAXR,MAXD) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8810 REFORMAT PROFILER EDITION 2 DATA -C PRGMMR: KEYSER ORG: NP22 DATE: 1995-06-07 -C -C ABSTRACT: REFORMAT PROFILER DATA IN EDITION 2 -C -C PROGRAM HISTORY LOG: -C 1993-01-27 CAVANAUGH -C 1995-06-07 KEYSER A CORRECTION WAS MADE TO PREVENT -C UNNECESSARY LOOPING WHEN ALL REQUESTED -C DESCRIPTORS ARE MISSING. -C -C USAGE: CALL FI8810(IDENT,MSTACK,KDATA,IPTR,MAXR,MAXD) -C INPUT ARGUMENT LIST: -C IDENT - ARRAY CONTAINS MESSAGE INFORMATION EXTRACTED FROM -C BUFR MESSAGE - -C IDENT(1) -EDITION NUMBER (BYTE 4, SECTION 1) -C IDENT(2) -ORIGINATING CENTER (BYTES 5-6, SECTION 1) -C IDENT(3) -UPDATE SEQUENCE (BYTE 7, SECTION 1) -C IDENT(4) - (BYTE 8, SECTION 1) -C IDENT(5) -BUFR MESSAGE TYPE (BYTE 9, SECTION 1) -C IDENT(6) -BUFR MSG SUB-TYPE (BYTE 10, SECTION 1) -C IDENT(7) - (BYTES 11-12, SECTION 1) -C IDENT(8) -YEAR OF CENTURY (BYTE 13, SECTION 1) -C IDENT(9) -MONTH OF YEAR (BYTE 14, SECTION 1) -C IDENT(10)-DAY OF MONTH (BYTE 15, SECTION 1) -C IDENT(11)-HOUR OF DAY (BYTE 16, SECTION 1) -C IDENT(12)-MINUTE OF HOUR (BYTE 17, SECTION 1) -C IDENT(13)-RSVD BY ADP CENTERS(BYTE 18, SECTION 1) -C IDENT(14)-NR OF DATA SUBSETS (BYTE 5-6, SECTION 3) -C IDENT(15)-OBSERVED FLAG (BYTE 7, BIT 1, SECTION 3) -C IDENT(16)-COMPRESSION FLAG (BYTE 7, BIT 2, SECTION 3) -C MSTACK - WORKING DESCRIPTOR LIST AND SCALING FACTOR -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C KSET2 - INTERIM DATA ARRAY -C KPROFL - INTERIM DESCRIPTOR ARRAY -C IPTR - SEE W3FI88 -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C -C OUTPUT FILES: -C -C REMARKS: -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ - INTEGER ISW - INTEGER IDENT(*),KDATA(MAXR,MAXD) - INTEGER MSTACK(2,MAXD),IPTR(*) - INTEGER KPROFL(1700) - INTEGER KPROF2(1700) - INTEGER KSET2(1700) -C - SAVE -C LOOP FOR NUMBER OF SUBSETS - DO 3000 I = 1, IDENT(14) - MK = 1 - JK = 0 - ISW = 0 -C PRINT *,'IDENTIFICATION' - DO 200 J = 1, 5 - IF (MSTACK(1,MK).EQ.257) THEN -C BLOCK NUMBER - ISW = ISW + 1 - ELSE IF (MSTACK(1,MK).EQ.258) THEN -C STATION NUMBER - ISW = ISW + 2 - ELSE IF (MSTACK(1,MK).EQ.1282) THEN -C LATITUDE - ISW = ISW + 4 - ELSE IF (MSTACK(1,MK).EQ.1538) THEN -C LONGITUDE - ISW = ISW + 8 - ELSE IF (MSTACK(1,MK).EQ.1793) THEN -C HEIGHT OF STATION - ISW = ISW + 16 - IHGT = KDATA(I,MK) - ELSE - MK = MK + 1 - GO TO 200 - END IF - JK = JK + 1 - KPROFL(JK) = MSTACK(1,MK) - KPROF2(JK) = MSTACK(2,MK) - KSET2(JK) = KDATA(I,MK) -C PRINT *,JK,KPROFL(JK),KSET2(JK) - MK = MK + 1 - 200 CONTINUE -C PRINT *,'LOCATION ',ISW - IF (ISW.NE.31) THEN - PRINT *,'LOCATION ERROR PROCESSING PROFILER' - IPTR(10) = 200 - RETURN - END IF -C PROCESS TIME ELEMENTS - ISW = 0 - DO 400 J = 1, 7 - IF (MSTACK(1,MK).EQ.1025) THEN -C YEAR - ISW = ISW + 1 - ELSE IF (MSTACK(1,MK).EQ.1026) THEN -C MONTH - ISW = ISW + 2 - ELSE IF (MSTACK(1,MK).EQ.1027) THEN -C DAY - ISW = ISW + 4 - ELSE IF (MSTACK(1,MK).EQ.1028) THEN -C HOUR - ISW = ISW + 8 - ELSE IF (MSTACK(1,MK).EQ.1029) THEN -C MINUTE - ISW = ISW + 16 - ELSE IF (MSTACK(1,MK).EQ.2069) THEN -C TIME SIGNIFICANCE - ISW = ISW + 32 - ELSE IF (MSTACK(1,MK).EQ.1049) THEN -C TIME DISPLACEMENT - ISW = ISW + 64 - ELSE - MK = MK + 1 - GO TO 400 - END IF - JK = JK + 1 - KPROFL(JK) = MSTACK(1,MK) - KPROF2(JK) = MSTACK(2,MK) - KSET2(JK) = KDATA(I,MK) -C PRINT *,JK,KPROFL(JK),KSET2(JK) - MK = MK + 1 - 400 CONTINUE -C PRINT *,'TIME ',ISW - IF (ISW.NE.127) THEN - PRINT *,'TIME ERROR PROCESSING PROFILER' - IPTR(1) = 201 - RETURN - END IF -C SURFACE DATA - ISW = 0 -C PRINT *,'SURFACE' - DO 600 K = 1, 8 -C PRINT *,MK,MSTACK(1,MK),JK,ISW - IF (MSTACK(1,MK).EQ.2817) THEN - ISW = ISW + 1 - ELSE IF (MSTACK(1,MK).EQ.2818) THEN - ISW = ISW + 2 - ELSE IF (MSTACK(1,MK).EQ.2611) THEN - ISW = ISW + 4 - ELSE IF (MSTACK(1,MK).EQ.3073) THEN - ISW = ISW + 8 - ELSE IF (MSTACK(1,MK).EQ.3342) THEN - ISW = ISW + 16 - ELSE IF (MSTACK(1,MK).EQ.3331) THEN - ISW = ISW + 32 - ELSE IF (MSTACK(1,MK).EQ.1797) THEN - INCRHT = KDATA(I,MK) - ISW = ISW + 64 -C PRINT *,'INITIAL INCREMENT = ',INCRHT - MK = MK + 1 -C PRINT *,JK,KPROFL(JK),KSET2(JK),' ISW=',ISW - GO TO 600 - ELSE IF (MSTACK(1,MK).EQ.6433) THEN - ISW = ISW + 128 - END IF - JK = JK + 1 - KPROFL(JK) = MSTACK(1,MK) - KPROF2(JK) = MSTACK(2,MK) - KSET2(JK) = KDATA(I,MK) -C PRINT *,JK,KPROFL(JK),KSET2(JK),'ISW=',ISW - MK = MK + 1 - 600 CONTINUE - IF (ISW.NE.255) THEN - PRINT *,'ERROR PROCESSING PROFILER',ISW - IPTR(1) = 204 - RETURN - END IF - IF (MSTACK(1,MK).NE.1797) THEN - PRINT *,'ERROR PROCESSING HEIGHT INCREMENT IN PROFILER' - IPTR(1) = 205 - RETURN - END IF -C MUST SAVE THIS HEIGHT VALUE - LHGT = 500 + IHGT - KDATA(I,MK) -C PRINT *,'BASE HEIGHT = ',LHGT,' INCR = ',INCRHT - MK = MK + 1 - IF (MSTACK(1,MK).GE.16384) THEN - MK = MK + 1 - END IF -C PROCESS LEVEL DATA -C PRINT *,'LEVEL DATA' - DO 2000 L = 1, 43 - 2020 CONTINUE -C PRINT *,'DESC',MK,MSTACK(1,MK),JK - ISW = 0 -C HEIGHT INCREMENT - IF (MSTACK(1,MK).EQ.1797) THEN - INCRHT = KDATA(I,MK) -C PRINT *,'NEW HEIGHT INCREMENT = ',INCRHT - MK = MK + 1 -C IF (LHGT.LT.(9250+IHGT)) THEN -C LHGT = IHGT + 500 - INCRHT -C ELSE -C LHGT = IHGT + 9250 -INCRHT -C END IF - END IF -C MUST ENTER HEIGHT OF THIS LEVEL - DESCRIPTOR AND DA -C AT THIS POINT - LHGT = LHGT + INCRHT -C PRINT *,'LEVEL ',L,LHGT -C IF (L.EQ.37) THEN -C LHGT = LHGT + INCRHT -C END IF - JK = JK + 1 -C SAVE DESCRIPTOR - KPROFL(JK) = 1798 -C SAVE SCALE - KPROF2(JK) = 0 -C SAVE DATA - KSET2(JK) = LHGT -C PRINT *,KPROFL(JK),KSET2(JK),JK - ISW = 0 - ICON = 1 - DO 800 J = 1, 10 -750 CONTINUE - IF (MSTACK(1,MK).EQ.1797) THEN - GO TO 2020 - ELSE IF (MSTACK(1,MK).EQ.6432) THEN -C HI/LO MODE - ISW = ISW + 1 - ELSE IF (MSTACK(1,MK).EQ.6434) THEN -C Q/C TEST - ISW = ISW + 2 - ELSE IF (MSTACK(1,MK).EQ.2070) THEN - IF (ICON.EQ.1) THEN -C FIRST PASS - U,V CONSENSUS - ISW = ISW + 4 - ICON = ICON + 1 - ELSE -C SECOND PASS - W CONSENSUS - ISW = ISW + 64 - END IF - ELSE IF (MSTACK(1,MK).EQ.2819) THEN -C U VECTOR VALUE - ISW = ISW + 8 - IF (KDATA(I,MK).GE.2047) THEN - VECTU = 32767 - ELSE - VECTU = KDATA(I,MK) - END IF - MK = MK + 1 - GO TO 800 - ELSE IF (MSTACK(1,MK).EQ.2820) THEN -C V VECTOR VALUE - ISW = ISW + 16 - IF (KDATA(I,MK).GE.2047) THEN - VECTV = 32767 - ELSE - VECTV = KDATA(I,MK) - END IF - IF (IAND(ISW,1).NE.0) THEN - IF (VECTU.EQ.32767.OR.VECTV.EQ.32767) THEN -C SAVE DD DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = 2817 - KPROF2(JK) = 0 - KSET2(JK) = 32767 -C SAVE FFF DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = 2818 - KPROF2(JK) = 1 - KSET2(JK) = 32767 - ELSE - CALL W3FC05 (VECTU,VECTV,DIR,SPD) - NDIR = DIR - SPD = SPD - NSPD = SPD -C PRINT *,' ',NDIR,NSPD -C SAVE DD DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = 2817 - KPROF2(JK) = 0 - KSET2(JK) = NDIR -C IF (I.EQ.1) THEN -C PRINT *,'DD ',JK,KPROFL(JK),KSET2(JK) -C ENDIF -C SAVE FFF DESCRIPTOR - JK = JK + 1 - KPROFL(JK) = 2818 - KPROF2(JK) = 1 - KSET2(JK) = NSPD -C IF (I.EQ.1) THEN -C PRINT *,'FFF',JK,KPROFL(JK),KSET2(JK) -C ENDIF - END IF - MK = MK + 1 - GO TO 800 - END IF - ELSE IF (MSTACK(1,MK).EQ.2866) THEN -C SPEED STD DEVIATION - ISW = ISW + 32 -C -- A CHANGE BY KEYSER : POWER DESCR. BACK TO 5568 - ELSE IF (MSTACK(1,MK).EQ.5568) THEN -C SIGNAL POWER - ISW = ISW + 128 - ELSE IF (MSTACK(1,MK).EQ.2822) THEN -C W COMPONENT - ISW = ISW + 256 - ELSE IF (MSTACK(1,MK).EQ.2867) THEN -C VERT STD DEVIATION - ISW = ISW + 512 -CVVVVVCHANGE#1 FIX BY KEYSER -- 12/06/1994 -C NOTE: THIS FIX PREVENTS UNNECESSARY LOOPING WHEN ALL REQ. DESCR. -C ARE MISSING. WOULD GO INTO INFINITE LOOP EXCEPT EVENTUALLY -C MSTACK ARRAY SIZE IS EXCEEDED AND GET FORTRAN ERROR INTERRUPT -CDAK ELSE - ELSE IF ((MSTACK(1,MK)/16384).NE.0) THEN -CAAAAACHANGE#1 FIX BY KEYSER -- 12/06/1994 - MK = MK + 1 - GO TO 750 - END IF - JK = JK + 1 -C SAVE DESCRIPTOR - KPROFL(JK) = MSTACK(1,MK) -C SAVE SCALE - KPROF2(JK) = MSTACK(2,MK) -C SAVE DATA - KSET2(JK) = KDATA(I,MK) - MK = MK + 1 -C PRINT *,L,'TEST ',JK,KPROFL(JK),KSET2(JK) - 800 CONTINUE - IF (ISW.NE.1023) THEN - PRINT *,'LEVEL ERROR PROCESSING PROFILER',ISW - IPTR(1) = 202 - RETURN - END IF - 2000 CONTINUE -C MOVE DATA BACK INTO KDATA ARRAY - DO 5000 LL = 1, JK -C DATA - KDATA(I,LL) = KSET2(LL) - 5000 CONTINUE - 3000 CONTINUE - DO 5005 LL = 1, JK -C DESCRIPTOR - MSTACK(1,LL) = KPROFL(LL) -C SCALE - MSTACK(2,LL) = KPROF2(LL) -C -- A CHANGE BY KEYSER : PRINT STATEMNT SHOULD BE HERE NOT IN 5000 LOOP -C PRINT *,LL,MSTACK(1,LL),MSTACK(2,LL),(KDATA(I,LL),I=1,4) - 5005 CONTINUE - IPTR(31) = JK - RETURN - END - SUBROUTINE FI8811(IPTR,IDENT,MSTACK,KDATA,KNR, - * LDATA,LSTACK,MAXD,MAXR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8811 EXPAND DATA/DESCRIPTOR REPLICATION -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 93-05-12 -C -C ABSTRACT: EXPAND DATA AND DESCRIPTOR STRINGS -C -C PROGRAM HISTORY LOG: -C 93-05-12 CAVANAUGH -C YY-MM-DD MODIFIER2 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8811(IPTR,IDENT,MSTACK,KDATA,KNR, -C * LDATA,LSTACK,MAXD,MAXR) -C INPUT ARGUMENT LIST: -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C IDENT - SEE W3FI88 ROUTINE DOCBLOCK -C MAXR - MAXIMUM NUMBER OF REPORTS/SUBSETS THAT MAY BE -C CONTAINED IN A BUFR MESSAGE -C MAXD - MAXIMUM NUMBER OF DESCRIPTOR COMBINATIONS THAT -C MAY BE PROCESSED; UPPER AIR DATA AND SOME SATELLITE -C DATA REQUIRE A VALUE FOR MAXD OF 1700, BUT FOR MOST -C OTHER DATA A VALUE FOR MAXD OF 500 WILL SUFFICE -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C MSTACK - LIST OF DESCRIPTORS AND SCALE VALUES -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C MSTACK - LIST OF DESCRIPTORS AND SCALE VALUES -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - -C -C REMARKS: ERROR RETURN: -C IPTR(1) = -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ - INTEGER IPTR(*) - INTEGER KNR(MAXR) - INTEGER KDATA(MAXR,MAXD),LDATA(MAXD) - INTEGER MSTACK(2,MAXD),LSTACK(2,MAXD) - INTEGER IDENT(*) -C - SAVE -C -C PRINT *,' DATA/DESCRIPTOR REPLICATION ' - DO 1000 I = 1, KNR(1) -C IF NOT REPLICATION DESCRIPTOR - IF ((MSTACK(1,I)/16384).NE.1) THEN - GO TO 1000 - END IF -C IF DELAYED REPLICATION DESCRIPTOR - IF (MOD(MSTACK(1,I),256).EQ.0) THEN -C SAVE KX VALUE (NR DESC'S TO REPLICATE) - KX = MOD((MSTACK(1,I)/256),64) -C IF NEXT DESC IS NOT 7947 OR 7948 -C (I.E., 0 31 011 OR 0 31 012) - IF (MSTACK(1,I+1).NE.7947.AND.MSTACK(1,I+1).NE.7948) THEN -C SKIP IT - GO TO 1000 - END IF -C GET NR REPS FROM KDATA - NRREPS = KDATA(1,I+1) - LAST = I + 1 + KX -C SAVE OFF TRAILING DESCS AND DATA - KTRAIL = KNR(1) - I - 1 - KX - DO 100 L = 1, KTRAIL - NX = I + L + KX + 1 - LDATA(L) = KDATA(1,NX) - LSTACK(1,L) = MSTACK(1,NX) - LSTACK(2,L) = MSTACK(2,NX) - 100 CONTINUE -C INSERT FX DESCS/DATA NR REPS TIMES - LAST = I + 1 - DO 400 J = 1, NRREPS - NX = I + 2 - DO 300 K = 1, KX - LAST = LAST + 1 - KDATA(1,LAST) = KDATA(1,NX) - MSTACK(1,LAST) = MSTACK(1,NX) - MSTACK(2,LAST) = MSTACK(2,NX) - NX = NX + 1 - 300 CONTINUE - - 400 CONTINUE -C RESTORE TRAILING DATA/DESCS - DO 500 L = 1, KTRAIL - LAST = LAST + 1 - KDATA(1,LAST) = LDATA(L) - MSTACK(1,LAST) = LSTACK(1,L) - MSTACK(2,LAST) = LSTACK(2,L) - 500 CONTINUE -C RESET KNR(1) - KNR(1) = LAST - END IF - 1000 CONTINUE - RETURN - END - SUBROUTINE FI8812(IPTR,IUNITB,IUNITD,ISTACK,NRDESC,KPTRB,KPTRD, - * IRF1SW,NEWREF,ITBLD,ITBLD2, - * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1, - * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8812 BUILD TABLE B SUBSET BASED ON BUFR SEC 3 -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 93-12-23 -C -C ABSTRACT: BUILD A SUBSET OF TABLE B ENTRIES THAT CORRESPOND TO -C THE DESCRIPTORS NEEDED FOR THIS MESSAGE -C -C PROGRAM HISTORY LOG: -C 93-05-12 CAVANAUGH -C YY-MM-DD MODIFIER2 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8812(IPTR,IUNITB,IUNITD,ISTACK,NRDESC,KPTRB,KPTRD, -C * IRF1SW,NEWREF,ITBLD,ITBLD2, -C * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1, -C * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2) -C INPUT ARGUMENT LIST: -C IPTR - SEE W3FI88 ROUTINE DOCBLOCK -C IDENT - SEE W3FI88 ROUTINE DOCBLOCK -C ISTACK - LIST OF DESCRIPTORS AND SCALE VALUES -C IUNITB - -C IUNITD - -C ISTACK - -C NRDESC - -C KFXY2 - -C ANAME2 - -C AUNIT2 - -C ISCAL2 - -C IRFVL2 - -C IWIDE2 - -C IRF1SW - -C NEWREF - -C ITBLD2 - -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C KDATA - ARRAY CONTAINING DECODED REPORTS FROM BUFR MESSAGE. -C KDATA(REPORT NUMBER,PARAMETER NUMBER) -C (REPORT NUMBER LIMITED TO VALUE OF INPUT ARGUMENT -C MAXR AND PARAMETER NUMBER LIMITED TO VALUE OF INPUT -C ARGUMENT MAXD) -C MSTACK - LIST OF DESCRIPTORS AND SCALE VALUES -C KFXY1 - -C ANAME1 - -C AUNIT1 - -C ISCAL1 - -C IRFVL1 - -C IWIDE1 - -C ITBLD - -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - -C -C REMARKS: ERROR RETURN: -C IPTR(1) = -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C .................................................. -C -C NEW BASE TABLE B -C MAY BE A COMBINATION OF MASTER TABLE B -C AND ANCILLARY TABLE B -C - INTEGER KFXY1(*),ISCAL1(*),IRFVL1(3,*),IWIDE1(*) - CHARACTER*40 ANAME1(*) - CHARACTER*24 AUNIT1(*) -C .................................................. -C -C NEW ANCILLARY TABLE B FROM TYPE 11 BUFR MESSAGE -C - INTEGER KFXY2(*),ISCAL2(*),IRFVL2(*),IWIDE2(*) - CHARACTER*64 ANAME2(*) - CHARACTER*24 AUNIT2(*) -C .................................................. -C -C ANCILLARY TABLE D FROM TYPE 11 BUFR MESSAGE -C - INTEGER ITBLD2(20,*) -C .................................................. -C -C NEW BASE TABLE D -C - INTEGER ITBLD(20,*) -C .................................................. - INTEGER IPTR(*),ISTACK(*),NRDESC,NWLIST(200) - INTEGER NEWREF(*),KPTRB(*),KPTRD(*) - INTEGER IUNITB,IUNITD,ICOPY(20000),NRCOPY,IELEM,IPOS - CHARACTER*64 AHLD64 - CHARACTER*24 AHLD24 -C - SAVE -C -C SCAN AND DISCARD REPLICATION AND OPERATOR DESCRIPTORS -C REPLACING SEQUENCE DESCRIPTORS WITH THEIR CORRESPONDING -C SET OF DESCRIPTORS ALSO ELIMINATING DUPLICATES. -C -C----------------------------------------------------------- -C PRINT *,'ENTER FI8812' -C - DO 10 I = 1, 16384 - KPTRB(I) = -1 - 10 CONTINUE -C -C -C - IF (IPTR(14).NE.0) THEN - DO I = 1, IPTR(14) - KPTRB(KFXY1(I)) = I - ENDDO - GO TO 9000 - END IF -C -C READ IN TABLE B - PRINT *,'FI8812 - READING TABLE B' - REWIND IUNITB - I = 1 - 4000 CONTINUE -C - READ(UNIT=IUNITB,FMT=20,ERR=9999,END=9000)MF, - * MX,MY, - * (ANAME1(I)(K:K),K=1,40), - * (AUNIT1(I)(K:K),K=1,24), - * ISCAL1(I),IRFVL1(1,I),IWIDE1(I) - 20 FORMAT(I1,I2,I3,40A1,24A1,I5,I15,1X,I4) - KFXY1(I) = MF*16384 + MX*256 + MY -C PRINT *,MF,MX,MY,KFXY1(I) - 5000 CONTINUE - KPTRB(KFXY1(I)) = I - IPTR(14) = I -C PRINT *,I -C WRITE(6,21) MF,MX,MY,KFXY1(I), -C * (ANAME1(I)(K:K),K=1,40), -C * (AUNIT1(I)(K:K),K=1,24), -C * ISCAL1(I),IRFVL1(1,I),IWIDE1(I) - 21 FORMAT(1X,I1,I2,I3,1X,I6,1X,40A1, - * 2X,24A1,2X,I5,2X,I15,1X,I4) - I = I + 1 - GO TO 4000 -C ====================================================== - 9999 CONTINUE -C ERROR READING TABLE B - PRINT *,'FI8812 - ERROR READING TABLE B - RECORD ',I - IPTR(1) = 9 - 9000 CONTINUE - IPTR(21) = IPTR(14) -C PRINT *,'EXIT FI8812 - IPTR(21) =',IPTR(21),' IPTR(1) =',IPTR(1) - RETURN - END - SUBROUTINE FI8813 (IPTR,MAXR,MAXD,MSTACK,KDATA,IDENT,KPTRD,KPTRB, - * ITBLD,ANAME1,AUNIT1,KFXY1,ISCAL1,IRFVL1,IWIDE1,IUNITB) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8813 EXTRACT TABLE A, TABLE B, TABLE D ENTRIES -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 94-03-04 -C -C ABSTRACT: EXTRACT TABLE A, TABLE B, TABLE D ENTRIES FROM A -C DECODED BUFR MESSAGE. -C -C PROGRAM HISTORY LOG: -C 94-03-04 CAVANAUGH -C YY-MM-DD MODIFIER1 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8813 (IPTR,MAXR,MAXD,MSTACK,KDATA,IDENT,KPTRD, -C * KPTRB,ITBLD,ANAME1,AUNIT1,KFXY1,ISCAL1,IRFVL1,IWIDE1,IUNITB) -C INPUT ARGUMENT LIST: -C IPTR -C MAXR -C MAXD -C MSTACK -C KDATA -C IDENT -C INARG1 - GENERIC DESCRIPTION, INCLUDING CONTENT, UNITS, -C INARG2 - TYPE. EXPLAIN FUNCTION IF CONTROL VARIABLE. -C -C OUTPUT ARGUMENT LIST: -C IUNITB -C ITBLD1 -C ANAME1 -C AUNIT1 -C KFXY1 -C ISCAL1 -C IRFVL1 -C IWIDE1 -C WRKARG - GENERIC DESCRIPTION, ETC., AS ABOVE. -C OUTARG1 - EXPLAIN COMPLETELY IF ERROR RETURN -C ERRFLAG - EVEN IF MANY LINES ARE NEEDED -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: INDICATE EXTENSIONS, COMPILER OPTIONS -C MACHINE: NAS, CYBER, WHATEVER -C -C$$$ -C .................................................. -C -C NEW ANCILLARY TABLE B FROM TYPE 11 BUFR MESSAGE -C - INTEGER KFXY1(*),ISCAL1(*),IRFVL1(*),IWIDE1(*) - CHARACTER*40 ANAME1(*) - CHARACTER*24 AUNIT1(*) -C .................................................. -C -C TABLE D -C - INTEGER ITBLD(20,*) -C .................................................. - CHARACTER*32 SPACES - CHARACTER*8 ASCCHR - CHARACTER*32 AAAA -C - INTEGER I1(20),I2(20),I3(20),KPTRB(*) - INTEGER IPTR(*),MAXR,MAXD,MSTACK(2,MAXD) - INTEGER IXA, IXB, IXD, KDATA(MAXR,MAXD) - INTEGER IEXTRA,KPTRD(*) - INTEGER KEYSET,ISCSGN(200),IRFSGN(200) - INTEGER IDENT(*),IHOLD,JHOLD(8),IUNITB - EQUIVALENCE (IHOLD,ASCCHR),(JHOLD,AAAA) - SAVE - DATA SPACES/' '/ - DATA IEXTRA/0/ - DATA KEYSET/0/ - -C ============================================================== -C PRINT *,'FI8813',IPTR(41),IPTR(42),IPTR(31),IPTR(21) -C BUILD SPACE CONSTANT -C INITIALIZE ENTRY COUNTS - IXA = 0 -C NUMBER IN TABLE B - IXB = IPTR(21) -C -C -C SET FOR COMPRESSED OR NON COMPRESSED -C PROCESSING -C -C PRINT *,'FI8813 - 2',IDENT(16),IDENT(14) - IF (IDENT(16).EQ.0) THEN - JK = 1 - ELSE - JK = IDENT(14) - END IF -C PRINT *,'FI8813 - 3, JK=',JK -C -C -C START PROCESSING ENTRIES -C PRINT *,'START PROCESSING ENTRIES' -C -C DO 995 I = 1, IPTR(31) -C IF (IPTR(45).EQ.4) THEN -C PRINT 9958,I,MSTACK(1,I),KDATA(1,I),KDATA(1,I) -C9958 FORMAT (1X,I5,2X,I5,2X,Z8,2X,A4) -C ELSE -C PRINT 9959,I,MSTACK(1,I),KDATA(1,I),KDATA(1,I) -C9959 FORMAT (1X,I5,2X,I5,2X,Z16,2X,A8) -C END IF -C 995 CONTINUE -C PRINT *,' ' - I = 0 - IEXTRA = 0 - 1000 CONTINUE -C -C SET POINTER TO CORRECT DATA POSITION -C I IS THE NUMBER OF DESCRIPTORS -C IEXTRA IS THE NUMBER OF WORDS ADDED -C FOR TEXT DATA -C - I = I + 1 - IF (I.GT.IPTR(31)) THEN -C RETURN IF COMPLETED SEARCH - GO TO 9000 - END IF - KLK = I + IEXTRA -C PRINT *,'ENTRY',KLK,I,IPTR(31),IEXTRA,MSTACK(1,KLK) -C -C IF TABLE A ENTRY OR EDITION NUMBER -C OR IF DESCRIPTOR IS NOT IN CLASS 0 -C SKIP OVER -C - IF (MSTACK(1,KLK).EQ.1) THEN -C PRINT *,'A ENTRY' - GO TO 1000 - ELSE IF (MSTACK(1,KLK).EQ.2) THEN -C PRINT *,'A ENTRY LINE 1' - IEXTRA = IEXTRA + 32 / IPTR(45) - 1 - GO TO 1000 - ELSE IF (MSTACK(1,KLK).EQ.3) THEN -C PRINT *,'A ENTRY LINE 2' - IEXTRA = IEXTRA + 32 / IPTR(45) - 1 - GO TO 1000 - ELSE IF (MSTACK(1,KLK).GE.34048.AND.MSTACK(1,KLK).LE.34303) THEN - LY = MOD(MSTACK(1,KLK),256) -C PRINT *,'CLASS C - HAVE',LY,' BYTES OF TEXT' - IF (MOD(LY,IPTR(45)).EQ.0) THEN - IWDS = LY / IPTR(45) - ELSE - IWDS = LY / IPTR(45) + 1 - END IF - IEXTRA = IEXTRA + IWDS - 1 - GO TO 1000 - ELSE IF (MSTACK(1,KLK).LT.10.OR.MSTACK(1,KLK).GT.255) THEN -C PRINT *,MSTACK(1,KLK),' NOT CLASS 0' - GO TO 1000 - END IF -C -C MUST FIND F X Y KEY FOR TABLE B -C OR TABLE D ENTRY -C - IZ = 1 - KEYSET = 0 - 10 CONTINUE - IF (I.GT.IPTR(31)) THEN - GO TO 9000 - END IF - KLK = I + IEXTRA - IF (MSTACK(1,KLK).GE.34048.AND.MSTACK(1,KLK).LE.34303) THEN - LY = MOD(MSTACK(1,KLK),256) -C PRINT *,'TABLE C - HAVE',LY,' TEXT BYTES' - IF (MOD(LY,4).EQ.0) THEN - IWDS = LY / IPTR(45) - ELSE - IWDS = LY / IPTR(45) + 1 - END IF - IEXTRA = IEXTRA + IWDS - 1 - I = I + 1 - GO TO 10 - ELSE IF (MSTACK(1,KLK)/16384.NE.0) THEN - IF (MOD(MSTACK(1,KLK),256).EQ.0) THEN - I = I + 1 - END IF - I = I + 1 - GO TO 10 - END IF - IF (MSTACK(1,KLK).GE.10.AND.MSTACK(1,KLK).LE.12) THEN -C PRINT *,'FIND KEY' -C -C MUST INCLUDE PROCESSING FOR COMPRESSED DATA -C -C BUILD DESCRIPTOR SEGMENT -C - IF (MSTACK(1,KLK).EQ.10) THEN - CALL FI8814 (KDATA(IZ,KLK),1,MF,IERR,IPTR) -C PRINT *,'F =',MF,KDATA(IZ,KLK),IPTR(31),I,IEXTRA - KEYSET = IOR(KEYSET,4) - ELSE IF (MSTACK(1,KLK).EQ.11) THEN - CALL FI8814 (KDATA(IZ,KLK),2,MX,IERR,IPTR) -C PRINT *,'X =',MX,KDATA(IZ1,KLK) - KEYSET = IOR(KEYSET,2) - ELSE IF (MSTACK(1,KLK).EQ.12) THEN - CALL FI8814 (KDATA(IZ,KLK),3,MY,IERR,IPTR) -C PRINT *,'Y =',MY,KDATA(IZ,KLK) - KEYSET = IOR(KEYSET,1) - END IF -C PRINT *,' KEYSET =',KEYSET - I = I + 1 - GO TO 10 - END IF - IF (KEYSET.EQ.7) THEN -C PRINT *,'HAVE KEY DESCRIPTOR',MF,MX,MY -C -C TEST NEXT DESCRIPTOR FOR TABLE B -C OR TABLE D ENTRY, PROCESS ACCORDINGLY -C - KLK = I + IEXTRA -C PRINT *,'DESC ',MSTACK(1,KLK),KLK,I,IEXTRA,KDATA(1,KLK) - IF (MSTACK(1,KLK).EQ.30) THEN - IXD = IPTR(20) + 1 - ITBLD(1,IXD) =16384 * MF + 256 * MX + MY -C PRINT *,'SEQUENCE DESCRIPTOR',MF,MX,MY,ITBLD(1,IXD) - GO TO 300 - ELSE IF (MSTACK(1,KLK).GE.13.AND.MSTACK(1,KLK).LE.20) THEN - KFXY1(IXB+IZ) = 16384 * MF + 256 * MX + MY -C PRINT *,'ELEMENT DESCRIPTOR',MF,MX,MY,KFXY1(IXB+IZ),IXB+IZ - KPTRB(KFXY1(IXB+IZ)) = IXB+IZ - GO TO 200 - ELSE - END IF -C I = I + 1 -C IF (I.GT.IPTR(31)) THEN -C GO TO 9000 -C END IF -C GO TO 10 - END IF - GO TO 1000 -C ================================================================== - 200 CONTINUE - IBFLAG = 1 - 20 CONTINUE - KLK = I + IEXTRA -C PRINT *,'ZZZ',KLK,I,IEXTRA,MSTACK(1,KLK),KDATA(IZ,KLK) - IF (MSTACK(1,KLK).LT.13.OR.MSTACK(1,KLK).GT.20) THEN - PRINT *,'IMPROPER SEQUENCE OF DESCRIPTORS IN LIST' -C =============================================================== - ELSE IF (MSTACK(1,KLK).EQ.13) THEN -C PRINT *,'13 NAME',KLK -C -C ELEMENT NAME PART 1 - 32 BYTES -C FOR THIS PARAMETER - JJ = IEXTRA - DO 21 LL = 1, 32, IPTR(45) - LLL = LL + IPTR(45) - 1 - KQK = I + JJ - IHOLD = KDATA(IZ,KQK) - IF (IPTR(37).EQ.0) THEN -C CALL W3AI39 (IDATA,IPTR(45)) - END IF - ANAME1(IXB+IZ)(LL:LLL) = ASCCHR - JJ = JJ + 1 - 21 CONTINUE - IEXTRA = IEXTRA + (32 / IPTR(45)) - 1 - IBFLAG = IOR(IBFLAG,64) -C =============================================================== - ELSE IF (MSTACK(1,KLK).EQ.14) THEN -C PRINT *,'14 NAME2',KLK -C -C ELEMENT NAME PART 2 - 32 BYTES -C -C FOR THIS PARAMETER - JJ = IEXTRA - DO 22 LL = 33, 64, IPTR(45) - LLL = LL + IPTR(45) - 1 - KQK = I + JJ - IHOLD = KDATA(IZ,KQK) - IF (IPTR(37).EQ.0) THEN -C CALL W3AI39 (ASCCHR,IPTR(45)) - END IF - ANAME1(IXB+IZ)(LL:LLL) = ASCCHR - JJ = JJ + 1 - 22 CONTINUE - IEXTRA = IEXTRA + (32 / IPTR(45)) - 1 - IBFLAG = IOR(IBFLAG,32) -C =============================================================== - ELSE IF (MSTACK(1,KLK).EQ.15) THEN -C PRINT *,'15 UNITS',KLK -C -C UNITS NAME - 24 BYTES -C -C FOR THIS PARAMETER - JJ = IEXTRA - DO 23 LL = 1, 24, IPTR(45) - LLL = LL + IPTR(45) - 1 - KQK = I + JJ - IHOLD = KDATA(IZ,KQK) - IF (IPTR(37).EQ.0) THEN -C CALL W3AI39 (ASCCHR,IPTR(45)) - END IF - AUNIT1(IXB+IZ)(LL:LLL) = ASCCHR - JJ = JJ + 1 - 23 CONTINUE - IEXTRA = IEXTRA + (24 / IPTR(45)) - 1 - IBFLAG = IOR(IBFLAG,16) -C =============================================================== - ELSE IF (MSTACK(1,KLK).EQ.16) THEN -C PRINT *,'16 SCALE SIGN' -C -C SCALE SIGN - 1 BYTE -C 0 = POS, 1 = NEG - IHOLD = KDATA(IZ,KLK) - KLK = I + IEXTRA - IF (INDEX(ASCCHR,'-').EQ.0) THEN - ISCSGN(IZ) = 1 - ELSE - ISCSGN(IZ) = -1 - END IF -C =============================================================== - ELSE IF (MSTACK(1,KLK).EQ.17) THEN -C PRINT *,'17 SCALE',KLK -C -C SCALE - 3 BYTES -C - KLK = I + IEXTRA - CALL FI8814(KDATA(IZ,KLK),3,ISCAL1(IXB+IZ),IERR,IPTR) - IF (IERR.NE.0) THEN - PRINT *,'NON-NUMERIC CHAR - CANNOT CONVERT' - IPTR(1) = 888 - GO TO 9000 - END IF - ISCAL1(IXB+IZ) = ISCAL1(IXB+IZ) * ISCSGN(IZ) - IBFLAG = IOR(IBFLAG,8) -C =============================================================== - ELSE IF (MSTACK(1,KLK).EQ.18) THEN -C PRINT *,'18 REFERENCE SCALE',KLK -C -C REFERENCE SIGN - 1 BYTE -C 0 = POS, 1 = NEG -C - KLK = I + IEXTRA - IHOLD = KDATA(IZ,KLK) - IF (INDEX(ASCCHR,'-').EQ.0) THEN - IRFSGN(IZ) = 1 - ELSE - IRFSGN(IZ) = -1 - END IF -C =============================================================== - ELSE IF (MSTACK(1,KLK).EQ.19) THEN -C PRINT *,'19 REFERENCE VALUE',KLK -C -C REFERENCE VALUE - 10 BYTES/ 3 WDS -C - JJ = IEXTRA - KQK = I + JJ - KM = 0 - DO 26 LL = 1, 12, IPTR(45) - KQK = I + JJ - KM = KM + 1 - JHOLD(KM) = KDATA(IZ,KQK) - JJ = JJ + 1 - 26 CONTINUE - CALL FI8814(AAAA,10,IRFVL1(IXB+IZ),IERR,IPTR) - IF (IERR.NE.0) THEN - PRINT *,'NON-NUMERIC CHARACTER-CANNOT CONVERT' - IPTR(1) = 888 - GO TO 9000 - END IF - IRFVL1(IXB+IZ) = IRFVL1(IXB+IZ) * IRFSGN(IZ) - IEXTRA = IEXTRA + 10 / IPTR(45) -C DO 261 IZ = 1, JK -C PRINT *,'RFVAL',IXB+IZ,JK,IRFVL1(IXB+IZ) -C 261 CONTINUE - IBFLAG = IOR(IBFLAG,4) -C =============================================================== - ELSE -C PRINT *,'20 WIDTH',KLK -C -C ELEMENT DATA WIDTH - 3 BYTES -C -C DO 27 LL = 1, 24, IPTR(45) - KLK = I + IEXTRA -C DO 270 IZ = 1, JK - CALL FI8814(KDATA(IZ,KLK),3,IWIDE1(IXB+IZ),IERR,IPTR) - IF (IERR.NE.0) THEN - PRINT *,'NON-NUMERIC CHAR - CANNOT CONVERT' - IPTR(1) = 888 - GO TO 9000 - END IF - IF (IWIDE1(IXB+IZ).LT.1) THEN - IPTR(1) = 890 -C PRINT *,'CLASS 0 DESCRIPTOR, WIDTH=0',KFXY1(IXB+IZ) - GO TO 9000 - END IF -C 270 CONTINUE -C 27 CONTINUE - IBFLAG = IOR(IBFLAG,2) - END IF -C NO, IT ISN'T -C -C IF THERE ARE ENOUGH OF THE ELEMENTS -C NECESSARY TO ACCEPT A TABLE B ENTRY -C -C PRINT *,' IBFLAG =',IBFLAG - IF (IBFLAG.EQ.127) THEN -C PRINT *,'COMPLETE TABLE B ENTRY' -C HAVE A COMPLETE TABLE B ENTRY - IXB = IXB + 1 -C PRINT *,'B',IXB,JK,KFXY1(IXB),ANAME1(IXB) -C PRINT *,' ',AUNIT1(IXB),ISCAL1(IXB), -C * IRFVL1(IXB),IWIDE1(IXB) - IPTR(21) = IXB - GO TO 1000 - END IF - I = I + 1 -C -C CHECK NEXT DESCRIPTOR -C - IF (I.GT.IPTR(31)) THEN -C RETURN IF COMPLETED SEARCH - GO TO 9000 - END IF - GO TO 20 -C ================================================================== - 300 CONTINUE - ISEQ = 0 - IJK = IPTR(20) + 1 -C PRINT *,'SEQUENCE DESCRIPTOR',MF,MX,MY,ITBLD(1,IXD),' FOR',IJK - 30 CONTINUE - KLK = I + IEXTRA -C PRINT *,'HAVE A SEQUENCE DESCRIPTOR',KLK,KDATA(IZ,KLK) - IF (MSTACK(1,KLK).EQ.30) THEN -C FROM TEXT FIELD (6 BYTES/2 WDS) -C STRIP OUT NEXT DESCRIPTOR IN SEQUENCE -C -C F - EXTRACT AND CONVERT TO DECIMAL - JJ = IEXTRA - KK = 0 - DO 351 LL = 1, 6, IPTR(45) - KQK = I + JJ - KK = KK + 1 - JHOLD(KK) = KDATA(1,KQK) - JJ = JJ + 1 - IF (LL.GT.1) IEXTRA = IEXTRA + 1 - 351 CONTINUE -C PRINT 349,KDATA(1,KQK) - 349 FORMAT (6X,Z24) -C CONVERT TO INTEGER - CALL FI8814(AAAA,6,IHOLD,IERR,IPTR) -C PRINT *,' ',IHOLD - IF (IERR.NE.0) THEN - PRINT *,'NON NUMERIC CHARACTER FOUND IN F X Y' - IPTR(1) = 888 - GO TO 9000 - END IF -C CONSTRUCT SEQUENCE DESCRIPTOR - IFF = IHOLD / 100000 - IXX = MOD((IHOLD/1300),100) - IYY = MOD(IHOLD,1300) -C INSERT IN PROPER SEQUENCE - ITBLD(ISEQ+2,IJK) = 16384 * IFF + 256 * IXX + IYY -C PRINT *,' SEQUENCE',IZ,AAAA,IHOLD,ITBLD(ISEQ+2,IJK), -C * IFF,IXX,IYY - ISEQ = ISEQ + 1 - IF (ISEQ.GT.18) THEN - IPTR(1) = 30 - RETURN - END IF -C SET TO LOOK AT NEXT DESCRIPTOR - I = I + 1 -C IF (IPTR(45).LT.6) THEN -C IEXTRA = IEXTRA + 1 -C END IF - GO TO 30 - ELSE -C NEXT DESCRIPTOR IS NOT A SEQUENCE DESCRIPTOR - IF (ISEQ.GE.1) THEN -C HAVE COMPLETE TABLE D ENTRY - IPTR(20) = IPTR(20) + 1 -C PRINT *,' INTO LOCATION ',IPTR(20) - LZ = ITBLD(1,IJK) - MZ = MOD(LZ,16384) - KPTRD(MZ) = IJK - I = I - 1 - END IF - END IF -C GO TEST NEXT DESCRIPTOR - GO TO 1000 -C ================================================================== - 9000 CONTINUE -C PRINT *,IPTR(21),' ENTRIES IN ANCILLARY TABLE B' -C PRINT *,IPTR(20),' ENTRIES IN ANCILLARY TABLE D' -C DO 9050 L = 1, 16384 -C IF (KPTRD(L).GT.0) PRINT *,' D',L+32768, KPTRD(L) -C9050 CONTINUE -C IF (I.GE.IPTR(31)) THEN -C -C FILE FOR MODIFIED TABLE B OUTPUT - NUMNUT = IUNITB + 1 - REWIND NUMNUT -C -C PRINT *,' HERE IS THE NEW TABLE B',IPTR(21) - DO 2000 KB = 1, IPTR(21) - JF = KFXY1(KB) / 16384 - JX = MOD((KFXY1(KB) / 256),64) - JY = MOD(KFXY1(KB),256) -C WRITE (6,2001)JF,JX,JY,ANAME1(KB), -C * AUNIT1(KB),ISCAL1(KB),IRFVL1(KB),IWIDE1(KB) - WRITE (NUMNUT,5000)JF,JX,JY,ANAME1(KB)(1:40), - * AUNIT1(KB)(1:24),ISCAL1(KB),IRFVL1(KB),IWIDE1(KB) - 5000 FORMAT(I1,I2,I3,A40,A24,I5,I15,I5) - 2000 CONTINUE - 2001 FORMAT (1X,I1,1X,I2,1X,I3,2X,A40,3X,A24,2X,I5,2X,I12, - * 2X,I4) -C - ENDFILE NUMNUT -C - IF (IPTR(20).NE.0) THEN -C PRINT OUT TABLE -C PRINT *,' HERE IS THE UPGRADED TABLE D' -C DO 3000 KB = 1, IPTR(20) -C PRINT 3001,KB,(ITBLD(K,KB),K=1,15) -C3000 CONTINUE -C3001 FORMAT (16(1X,I5)) - END IF -C EXIT ROUTINE, ALL DONE WITH PASS -C END IF - RETURN - END - SUBROUTINE FI8814 (ASCCHR,NPOS,NEWVAL,IERR,IPTR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8814 CONVERT TEXT TO INTEGER -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 94-03-04 -C -C ABSTRACT: CONVERT TEXT CHARACTERS TO INTEGER VALUE -C -C PROGRAM HISTORY LOG: -C 94-03-04 CAVANAUGH -C YY-MM-DD MODIFIER2 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8814 (ASCCHR,NPOS,NEWVAL,IERR,IPTR) -C INPUT ARGUMENT LIST: -C ASCCHR - -C NPOS - -C NEWVAL - -C IERR - -C INARG1 - GENERIC DESCRIPTION, INCLUDING CONTENT, UNITS, -C INARG2 - TYPE. EXPLAIN FUNCTION IF CONTROL VARIABLE. -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C WRKARG - GENERIC DESCRIPTION, ETC., AS ABOVE. -C OUTARG1 - EXPLAIN COMPLETELY IF ERROR RETURN -C ERRFLAG - EVEN IF MANY LINES ARE NEEDED -C -C INPUT FILES: (DELETE IF NO INPUT FILES IN SUBPROGRAM) -C DDNAME1 - GENERIC NAME & CONTENT -C -C OUTPUT FILES: (DELETE IF NO OUTPUT FILES IN SUBPROGRAM) -C DDNAME2 - GENERIC NAME & CONTENT AS ABOVE -C FT06F001 - INCLUDE IF ANY PRINTOUT -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: INDICATE EXTENSIONS, COMPILER OPTIONS -C MACHINE: NAS, CYBER, WHATEVER -C -C$$$ - INTEGER IERR, IHOLD, IPTR(*) - CHARACTER*8 AHOLD - CHARACTER*64 ASCCHR - EQUIVALENCE (IHOLD,AHOLD) - - SAVE -C ---------------------------------------------------------- - IERR = 0 - NEWVAL = 0 - IFLAG = 0 -C - DO 1000 I = 1, NPOS - IHOLD = 0 - AHOLD(IPTR(45):IPTR(45)) = ASCCHR(I:I) - IF (IPTR(37).EQ.1) THEN - IF (IHOLD.EQ.32) THEN - IF (IFLAG.EQ.0) GO TO 1000 - GO TO 2000 - ELSE IF (IHOLD.LT.48.OR.IHOLD.GT.57) THEN -C PRINT*,' ASCII IHOLD =',IHOLD - IERR = 1 - RETURN - ELSE - IFLAG = 1 - NEWVAL = NEWVAL * 10 + IHOLD - 48 - END IF - ELSE - IF (IHOLD.EQ.64) THEN - IF (IFLAG.EQ.0) GO TO 1000 - GO TO 2000 - ELSE IF (IHOLD.LT.240.OR.IHOLD.GT.249) THEN -C PRINT*,' EBCIDIC IHOLD =',IHOLD - IERR = 1 - RETURN - ELSE - IFLAG = 1 - NEWVAL = NEWVAL * 10 + IHOLD - 240 - END IF - END IF - 1000 CONTINUE - 2000 CONTINUE - RETURN - END - SUBROUTINE FI8815(IPTR,IDENT,JDESC,KDATA,KFXY3,MAXR,MAXD, - * ANAME3,AUNIT3, - * ISCAL3,IRFVL3,IWIDE3, - * KEYSET,IBFLAG,IERR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8815 EXTRACT TABLE A, TABLE B, TABLE D ENTRIES -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 94-03-04 -C -C ABSTRACT: EXTRACT TABLE A, TABLE B, ENTRIES FROM ACTIVE BUFR MESSAGE -C TO BE RETAINED FOR USE DURING THE DECODING OF ACTIVE BUFR MESSAGE. -C THESE WILL BE DISCARDED WHEN DECODING OF CURRENT MESSAGE IS COMPLETE -C -C PROGRAM HISTORY LOG: -C 94-03-04 CAVANAUGH -C YY-MM-DD MODIFIER1 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8815(IPTR,IDENT,JDESC,KDATA,KFXY3,MAXR,MAXD, -C * ANAME3,AUNIT3, -C * ISCAL3,IRFVL3,IWIDE3, -C * KEYSET,IBFLAG,IERR) -C INPUT ARGUMENT LIST: -C IPTR - -C MAXR - -C MAXD - -C MSTACK - -C KDATA - -C IDENT - -C INARG1 - GENERIC DESCRIPTION, INCLUDING CONTENT, UNITS, -C INARG2 - TYPE. EXPLAIN FUNCTION IF CONTROL VARIABLE. -C -C OUTPUT ARGUMENT LIST: -C ANAME3 - -C AUNIT3 - -C KFXY3 - -C ISCAL3 - -C IRFVL3 - -C IWIDE3 - -C WRKARG - GENERIC DESCRIPTION, ETC., AS ABOVE. -C OUTARG1 - EXPLAIN COMPLETELY IF ERROR RETURN -C ERRFLAG - EVEN IF MANY LINES ARE NEEDED -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: INDICATE EXTENSIONS, COMPILER OPTIONS -C MACHINE: NAS, CYBER -C -C$$$ - CHARACTER*64 ANAME3(*),SPACES - CHARACTER*24 AUNIT3(*) -C - INTEGER IPTR(*),MAXR,MAXD,JDESC - INTEGER IXA, IXB, IXD, KDATA(MAXR,MAXD) - INTEGER IEXTRA - INTEGER KEYSET - INTEGER KFXY3(*),IDENT(*) - INTEGER ISCAL3(*),ISCSGN(150) - INTEGER IRFVL3(*),IRFSGN(150) - INTEGER IWIDE3(*) - - SAVE -C ============================================================== -C PRINT *,'FI8815' - IEXTRA = 0 -C BUILD SPACE CONSTANT - DO 1 I = 1, 64 - SPACES(I:I) = ' ' - 1 CONTINUE -C INITIALIZE ENTRY COUNTS - IXA = 0 - IXB = 0 - IXD = 0 -C -C SET FOR COMPRESSED OR NON COMPRESSED -C PROCESSING -C - IF (IDENT(16).EQ.0) THEN - JK = 1 - ELSE - JK = IDENT(14) - END IF -C -C CLEAR NECESSARY ENTRIES -C - DO 2 IY = 1, JK -C -C CLEAR NEXT TABLE B ENTRY -C - KFXY3(IXB+IY) = 0 - ANAME3(IXB+IY)(1:64) = SPACES(1:64) - AUNIT3(IXB+IY)(1:24) = SPACES(1:24) - ISCAL3(IXB+IY) = 0 - IRFVL3(IXB+IY) = 0 - IWIDE3(IXB+IY) = 0 - ISCSGN(IY) = 1 - IRFSGN(IY) = 1 - 2 CONTINUE -C -C START PROCESSING ENTRIES -C - I = 0 - 1000 CONTINUE -C -C SET POINTER TO CORRECT DATA POSITION -C - K = I + IEXTRA -C -C MUST FIND F X Y KEY FOR TABLE B -C OR TABLE D ENTRY -C - IF (JDESC.GE.10.AND.JDESC.LE.12) THEN - 10 CONTINUE -C -C BUILD DESCRIPTOR SEGMENT -C - DO 20 LY = 1,JK - IF (JDESC.EQ.10) THEN - KFXY3(IXB+LY) = KDATA(K,1) * 16384 + KFXY3(IXB+LY) - KEYSET = IOR(KEYSET,4) - I = I + 1 - GO TO 10 - ELSE IF (JDESC.EQ.11) THEN - KFXY3(IXB+LY) = KDATA(K,1) * 256 + KFXY3(IXB+LY) - KEYSET = IOR(KEYSET,2) - I = I + 1 - GO TO 10 - ELSE IF (JDESC.EQ.12) THEN - KFXY3(IXB+LY) = KDATA(K,1) + KFXY3(IXB+LY) - KEYSET = IOR(KEYSET,1) - END IF - 20 CONTINUE -C ================================================================== - ELSE IF (JDESC.GE.13.AND.JDESC.LE.20) THEN - DO 250 IZ = 1, JK - IF (JDESC.EQ.13) THEN -C -C ELEMENT NAME PART 1 - 32 BYTES/8 WDS -C - CALL GBYTES (ANAME3(IXB+IZ),KDATA(K,IZ),0,32,0,8) - IBFLAG = IOR(IBFLAG,16) - ELSE IF (JDESC.EQ.14) THEN -C -C ELEMENT NAME PART 2 - 32 BYTES/8 WDS -C - CALL GBYTES(ANAME3(IXB+IZ)(33:33),KDATA(K,IZ),0,32,0,8) - ELSE IF (JDESC.EQ.15) THEN -C -C UNITS NAME - 24 BYTES/6 WDS -C - CALL GBYTES (AUNIT3(IXB+IZ)(1:1),KDATA(K,IZ),0,32,0,6) - IBFLAG = IOR(IBFLAG,8) - ELSE IF (JDESC.EQ.16) THEN -C -C UNITS SCALE SIGN - 1 BYTE/ 1 WD -C 0 = POS, 1 = NEG - IF (KDATA(K,1).NE.48) THEN - ISCSGN(IZ) = -1 - ELSE - ISCSGN(IZ) = 1 - END IF - ELSE IF (JDESC.EQ.17) THEN -C -C UNITS SCALE - 3 BYTES/ 1 WD -C - CALL FI8814(KDATA(K,IZ),3,ISCAL3(IXB+IZ),IERR,IPTR) - IF (IERR.NE.0) THEN - PRINT *,'NON-NUMERIC CHARACTER - CANNOT CONVERT' - IPTR(1) = 888 - RETURN - END IF - IBFLAG = IOR(IBFLAG,4) - ELSE IF (JDESC.EQ.18) THEN -C -C UNITS REFERENCE SIGN - 1 BYTE/ 1 WD -C 0 = POS, 1 = NEG -C - IF (KDATA(K,1).EQ.48) THEN - IRFSGN(IZ) = 1 - ELSE - IRFSGN(IZ) = -1 - END IF - ELSE IF (JDESC.EQ.19) THEN -C -C UNITS REFERENCE VALUE - 10 BYTES/ 3 WDS -C - CALL FI8814(KDATA(K,IZ),10,IRFVL3(IXB+IZ),IERR,IPTR) - IF (IERR.NE.0) THEN - PRINT *,'NON-NUMERIC CHARACTER-CANNOT CONVERT' - IPTR(1) = 888 - RETURN - END IF - IBFLAG = IOR(IBFLAG,2) - ELSE -C -C ELEMENT DATA WIDTH - 3 BYTES/ 1 WD -C - CALL FI8814(KDATA(K,1),3,IWIDE3(IXB+1),IERR,IPTR) - IF (IERR.NE.0) THEN - PRINT *,'NON-NUMERIC CHARACTER-CANNOT CONVERT' - IPTR(1) = 888 - RETURN - END IF - IBFLAG = IOR(IBFLAG,1) - END IF - 250 CONTINUE - END IF -C ================================================================== - 9000 RETURN - END - SUBROUTINE FI8818(IPTR, - * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1, - * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2, - * KPTRB) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8818 MERGE ANCILLARY & STANDARD B ENTRIES -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: YY-MM-DD -C -C ABSTRACT: START ABSTRACT HERE AND INDENT TO COLUMN 5 ON THE -C FOLLOWING LINES. SEE NMC HANDBOOK SECTION 3.1.1. FOR DETAILS -C -C PROGRAM HISTORY LOG: -C YY-MM-DD CAVANAUGH -C YY-MM-DD MODIFIER1 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8818(IPTR, -C * KFXY1,ANAME1,AUNIT1,ISCAL1,IRFVL1,IWIDE1, -C * KFXY2,ANAME2,AUNIT2,ISCAL2,IRFVL2,IWIDE2,KPTRB) -C INPUT ARGUMENT LIST: -C IPTR - -C KFXY1 - -C ANAME1 - -C AUNIT1 - -C ISCAL1 - -C IRFVL1 - -C IWIDE1 - -C KFXY2 - -C ANAME2 - -C AUNIT2 - -C ISCAL2 - -C IRFVL2 - -C IWIDE2 - -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IPTR - -C KFXY1 - -C ANAME1 - -C AUNIT1 - -C ISCAL1 - -C IRFVL1 - -C IWIDE1 - -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: INDICATE EXTENSIONS, COMPILER OPTIONS -C MACHINE: NAS, CYBER, WHATEVER -C -C$$$ -C .................................................. -C -C NEW BASE TABLE B -C MAY BE A COMBINATION OF MASTER TABLE B -C AND ANCILLARY TABLE B -C - INTEGER KFXY1(*),ISCAL1(*),IRFVL1(3,*),IWIDE1(*) - CHARACTER*40 ANAME1(*) - CHARACTER*24 AUNIT1(*) -C .................................................. -C -C NEW ANCILLARY TABLE B FROM TYPE 11 BUFR MESSAGE -C - INTEGER KFXY2(*),ISCAL2(*),IRFVL2(*),IWIDE2(*) - CHARACTER*64 ANAME2(*) - CHARACTER*24 AUNIT2(*) -C .................................................. - INTEGER IPTR(*),KPTRB(*) - - SAVE -C -C SET UP POINTERS -C PRINT *,'FI8818-A',IPTR(21),IPTR(41) - KAB = 1 - KB = 1 - 1000 CONTINUE -C PRINT *,KB,KAB,KFXY1(KB),KFXY2(KAB),IPTR(21) - IF (KB.GT.IPTR(21)) THEN -C NO MORE MASTER ENTRIES -C PRINT *,'NO MORE MASTER ENTRIES' - IF (KAB.GT.IPTR(41)) THEN - GO TO 5000 - END IF -C APPEND ANCILLARY ENTRY - GO TO 2000 - ELSE IF (KB.LE.IPTR(21)) THEN -C HAVE MORE MASTER ENTRIES - IF (KAB.GT.IPTR(41)) THEN -C NO MORE ANCILLARY ENTRIES - GO TO 5000 - END IF - IF (KFXY2(KAB).EQ.KFXY1(KB)) THEN -C REPLACE MASTER ENTRY - GO TO 3000 - ELSE IF (KFXY2(KAB).LT.KFXY1(KB)) THEN -C INSERT ANCILLARY ENTRY - GO TO 2000 - ELSE IF (KFXY2(KAB).GT.KFXY1(KB)) THEN -C SKIP MASTER ENTRY - KB = KB + 1 - END IF - END IF - GO TO 1000 - 2000 CONTINUE - IPTR(21) = IPTR(21) + 1 - KPTRB(KFXY2(KAB)) = IPTR(21) -C APPEND ANCILLARY ENTRY - KFXY1(IPTR(21)) = KFXY2(KAB) - ANAME1(IPTR(21))(1:40) = ANAME2(KAB)(1:40) - AUNIT1(IPTR(21)) = AUNIT2(KAB) - ISCAL1(IPTR(21)) = ISCAL2(KAB) - IRFVL1(1,IPTR(21)) = IRFVL2(KAB) - IWIDE1(IPTR(21)) = IWIDE2(KAB) -C PRINT *,IPTR(21),KFXY1(IPTR(21)),' APPENDED' - KAB = KAB + 1 - GO TO 1000 - 3000 CONTINUE -C REPLACE MASTER ENTRY - KFXY1(KB) = KFXY2(KAB) - ANAME1(KB) = ANAME2(KAB)(1:40) - AUNIT1(KB) = AUNIT2(KAB) - ISCAL1(KB) = ISCAL2(KAB) - IRFVL1(1,KB) = IRFVL2(KAB) - IWIDE1(KB) = IWIDE2(KAB) -C PRINT *,KB,KFXY1(KB),'REPLACED',IWIDE1(KB) - KAB = KAB + 1 - KB = KB + 1 - GO TO 1000 - 5000 CONTINUE - IPTR(41) = 0 -C PROCESSING COMPLETE -C PRINT *,'FI8818-B',IPTR(21),IPTR(41) -C DO 6000 I = 1, IPTR(21) -C PRINT *,'FI8818-C',I,KFXY1(I),IWIDE1(I) -C6000 CONTINUE - RETURN - END - SUBROUTINE FI8819(IPTR,ITBLD,ITBLD2,KPTRD) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8819 MERGE ANCILLARY & MASTER TABLE D -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: YY-MM-DD -C -C ABSTRACT: MERGE TABLE D ENTRIES WITH THE ENTRIES FROM THE STANDARD -C TABLE D. ASSURE THAT ENTRIES ARE SEQUENTIAL. -C -C PROGRAM HISTORY LOG: -C YY-MM-DD CAVANAUGH -C YY-MM-DD MODIFIER1 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8819(IPTR,ITBLD,ITBLD2,KPTRD) -C INPUT ARGUMENT LIST: -C IPTR - -C ITBLD - -C ITBLD2 - -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IPTR - -C ITBLD - -C -C REMARKS: LIST CAVEATS, OTHER HELPFUL HINTS OR INFORMATION -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS, CYBER -C -C$$$ -C .................................................. -C -C ANCILLARY TABLE D FROM TYPE 11 BUFR MESSAGE -C - INTEGER ITBLD2(20,*) -C .................................................. -C -C NEW BASE TABLE D -C - INTEGER ITBLD(20,*) -C .................................................. - INTEGER IPTR(*),KPTRD(*) - - SAVE -C PRINT *,'FI8819-A',IPTR(20),IPTR(42) -C SET UP POINTERS - DO 1000 I = 1, IPTR(42) - IPTR(20) = IPTR(20) + 1 - DO 500 J = 1, 20 - ITBLD(J,IPTR(20)) = ITBLD2(J,I) - MPTRD = MOD(ITBLD(J,IPTR(20)),16384) - KPTRD(MPTRD) = IPTR(20) - 500 CONTINUE - 1000 CONTINUE -C ======================================================= - IPTR(42) = 0 -C PRINT *,'MERGED TABLE D -- FI8819-B',IPTR(20),IPTR(42) -C DO 6000 I = 1, IPTR(20) -C WRITE (6,6001)I,(ITBLD(J,I),J=1,20) -C6001 FORMAT(15(1X,I5)) -C6000 CONTINUE - RETURN - END - SUBROUTINE FI8820 (ITBLD,IUNITD,IPTR,ITBLD2,KPTRD) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: FI8820 READ IN BUFR TABLE D -C PRGMMR: CAVANAUGH ORG: W/NMC42 DATE: 93-05-06 -C -C ABSTRACT: READ IN BUFR TABLE D -C -C PROGRAM HISTORY LOG: -C 93-05-06 CAVANAUGH -C YY-MM-DD MODIFIER1 DESCRIPTION OF CHANGE -C -C USAGE: CALL FI8820 (ITBLD,IUNITD,IPTR,ITBLD2,KPTRD) -C INPUT ARGUMENT LIST: -C IUNITD - UNIT NUMBER FOR TABLE D INPUT -C IPTR - ARRAY OF WORKING VALUES -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C ITBLD - ARRAY TO CONTAIN TABLE D -C -C REMARKS: -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: NAS -C -C$$$ -C .................................................. -C -C ANCILLARY TABLE D FROM TYPE 11 BUFR MESSAGE -C - INTEGER ITBLD2(20,*) -C .................................................. -C -C NEW BASE TABLE D -C - INTEGER ITBLD(20,*) -C .................................................. -C - INTEGER IHOLD(33),IPTR(*),KPTRD(*) - LOGICAL MORE - - SAVE -C - MORE = .TRUE. - I = 0 -C -C READ IN TABLE D, BUT JUST ONCE -C PRINT *,'TABLE D SWITCH=',IPTR(20),' ANCILLARY D SW=',IPTR(42) - IF (IPTR(20).EQ.0) THEN - DO 1000 MM = 1, 16384 - KPTRD(MM) = -1 - 1000 CONTINUE - IERR = 0 - PRINT *,'FI8820 - READING TABLE D' - KEY = 0 - 100 CONTINUE -C READ NEXT TABLE D ENTRY - READ(IUNITD,15,ERR=9998,END=9000)(IHOLD(M),M=1,33) - 15 FORMAT(11(I1,I2,I3,1X),3X) -C BUILD KEY FROM MASTER D ENTRY -C INSERT NEW MASTER INTO TABLE B - I = I + 1 - IPTR(20) = IPTR(20) + 1 - DO 25 JJ = 1, 41, 3 - KK = (JJ/3) + 1 - IF (JJ.LE.31) THEN - ITBLD(KK,I) = IHOLD(JJ)*16384 + - * IHOLD(JJ+1)*256 + IHOLD(JJ+2) - IF (ITBLD(KK,I).LT.1.OR.ITBLD(KK,I).GT.65535) THEN - ITBLD(KK,I) = 0 - GO TO 25 - END IF - ELSE - ITBLD(KK,I) = 0 - END IF - 25 CONTINUE - MPTRD = MOD(ITBLD(1,I),16384) - KPTRD(MPTRD) = I - 50 CONTINUE -C WRITE (6,51)I,(ITBLD(L,I),L=1,15) - 51 FORMAT (7H TABLED,16(1X,I5)) - GO TO 100 - ELSE -C PRINT *,'TABLE D IS IN PLACE' - END IF - GO TO 9999 - 9000 CONTINUE - CLOSE(UNIT=IUNITD,STATUS='KEEP') - GO TO 9999 - 9998 CONTINUE - IPTR(1) = 8 -C - 9999 CONTINUE -C PRINT *,'THERE ARE',IPTR(20),' ENTRIES IN TABLE D' - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fi92.f b/external/w3nco/v2.0.6/src/w3fi92.f deleted file mode 100644 index ac1f9cca3..000000000 --- a/external/w3nco/v2.0.6/src/w3fi92.f +++ /dev/null @@ -1,216 +0,0 @@ - SUBROUTINE W3FI92 (LOC,TTAAII,KARY,KWBX,IERR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FI92 BUILD 80-CHAR ON295 GRIB QUEUE DESCRIPTOR -C PRGMMR: CAVANAUGH ORG: NMC421 DATE:95-01-31 -C -C ABSTRACT: BUILD 80 CHARACTER QUEUE DESCRIPTOR USING INFORMATION -C SUPPLIED BY USER, PLACING THE COMPLETED QUEUE DESCRIPTOR IN THE -C LOCATION SPECIFIED BY THE USER. (BASED ON OFFICE NOTE 295). -C NOTE - THIS IS A MODIFIED VERSION OF W3FI62 WHICH ADDS THE -C 'KWBX' PARAMETER. THIS VALUE WILL NOW BE ADDED TO -C BYTES 35-38 FOR ALL GRIB PRODUCTS. -C QUEUE DESCIPTORS FOR NON-GRIB PRODUCTS WILL CONTINUE -C TO BE GENERATYED BY W3FI62. -C -C PROGRAM HISTORY LOG: -C 91-06-21 CAVANAUGH -C 94-03-08 CAVANAUGH MODIFIED TO ALLOW FOR BULLETIN SIZES THAT -C EXCEED 20000 BYTES -C 94-04-28 R.E.JONES CHANGE FOR CRAY 64 BIT WORD SIZE AND -C FOR ASCII CHARACTER SET COMPUTERS -C 95-10-16 J.SMITH MODIFIED VERSION OF W3FI62 TO ADD 'KWBX' -C TO BYTES 35-38 OF QUEUE DESCRIPTOR. -C 96-01-29 R.E.JONES PRESET IERR TO ZERO. -C 02-10-15 VUONG REPLACED FUNCTION ICHAR WITH MOVA2I -C -C USAGE: CALL W3FI92 (LOC,TTAAII,KARY,KWBX,IERR) -C INPUT ARGUMENT LIST: -C TTAAII - FIRST 6 CHARACTERS OF WMO HEADER -C KARY - INTEGER ARRAY CONTAINING USER INFORMATION -C (1) = DAY OF MONTH -C (2) = HOUR OF DAY -C (3) = HOUR * 100 + MINUTE -C (4) = CATALOG NUMBER -C (5) = NUMBER OF 80 BYTE INCREMENTS -C (6) = NUMBER OF BYTES IN LAST INCREMENT -C (7) = TOTAL SIZE OF MESSAGE -C WMO HEADER + BODY OF MESSAGE IN BYTES -C (NOT INCLUDING QUEUE DESCRIPTOR) -C KWBX - = 4 CHARACTERS, REPRESENTING TH FCST MODEL -C THAT THE BULLETIN WAS DERIVED FROM. -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C LOC - LOCATION TO RECEIVE QUEUE DESCRIPTOR -C KARY - SEE INPUT ARGUMENT LIST -C IERR - ERROR RETURN -C -C SUBPROGRAMS CALLED: (LIST ALL CALLED FROM ANYWHERE IN CODES) -C LIBRARY: -C W3LIB - GBYTE W3FI01 W3AI15 W3AI39 -C -C REMARKS: IF TOTAL SIZE IS ENTERED (KARY(7)) THEN KARY(5) AND -C KARY(6) WILL BE CALCULATED. -C IF KARY(5) AND KARY(6) ARE PROVIDED THEN KARY(7) WILL -C BE IGNORED. -C -C WARNING: EQUIVALENCE ARRAY LOC TO INTEGER ARRAY SO IT STARTS ON -C A WORD BOUNDARY FOR SBYTE SUBROUTINE. -C -C ERROR RETURNS -C IERR = 1 TOTAL BYTE COUNT AND/OR 80 BYTE INCREMENT -C COUNT IS MISSING. ONE OR THE OTHER IS -C REQUIRED TO COMPLETE THE QUEUE DESCRIPTOR. -C IERR = 2 TOTAL SIZE TOO SMALL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 77 -C MACHINE: HDS -C -C$$$ -C - INTEGER IHOLD(2) - INTEGER KARY(7),IERR -C - LOGICAL IBM370 -C - CHARACTER*6 TTAAII,AHOLD - CHARACTER*80 LOC - CHARACTER*1 BLANK - CHARACTER*4 KWBX -C - EQUIVALENCE (AHOLD,IHOLD) -C - SAVE -C -C BLANK WILL BE 40 HEX OR DECIMAL 64 ON AN IBM370 TYPE -C COMPUTER, THIS IS THE EBCDIC CHARACTER SET. -C BLANK WILL BE 20 HEX OR DECIMAL 32 ON A COMPUTER WITH THE -C ASCII CHARACTER SET. THIS WILL BE USED TO TEST FOR CHARACTER -C SETS TO FIND IBM370 TYPE COMPUTER. -C - DATA BLANK /' '/ -C ---------------------------------------------------------------- -C -C TEST FOR CRAY 64 BIT COMPUTER, LW = 8 -C - CALL W3FI01(LW) -C -C TEST FOR EBCDIC CHARACTER SET -C - IBM370 = .FALSE. - IF (MOVA2I(BLANK).EQ.64) THEN - IBM370 = .TRUE. - END IF -C - INOFST = 0 -C BYTES 1-16 'QUEUE DESCRIPTOR' - CALL SBYTE (LOC,-656095772,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,-985611067,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,-490481207,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,-672934183,INOFST,32) - INOFST = INOFST + 32 -C BYTES 17-20 INTEGER ZEROES - CALL SBYTE (LOC,0,INOFST,32) - INOFST = INOFST + 32 -C IF TOTAL COUNT IS INCLUDED -C THEN WILL DETERMINE THE NUMBER OF -C 80 BYTE INCREMENTS AND WILL DETERMINE -C THE NUMBER OF BYTES IN THE LAST INCREMENT - IERR = 0 - IF (KARY(7).NE.0) THEN - IF (KARY(7).LT.35) THEN -C PRINT *,'LESS THAN MINIMUM SIZE' - IERR = 2 - RETURN - END IF - KARY(5) = KARY(7) / 80 - KARY(6) = MOD(KARY(7),80) - IF (KARY(6).EQ.0) THEN - KARY(6) = 80 - ELSE - KARY(5) = KARY(5) + 1 - END IF - ELSE - IF (KARY(5).LT.1) THEN - IERR = 1 - RETURN - END IF - END IF -C BYTE 21-22 NR OF 80 BYTE INCREMENTS - CALL SBYTE (LOC,KARY(5),INOFST,16) - INOFST = INOFST + 16 -C BYTE 23 NR OF BYTES IN LAST INCREMENT - CALL SBYTE (LOC,KARY(6),INOFST,8) - INOFST = INOFST + 8 -C BYTES 24-28 INTEGER ZEROES - CALL SBYTE (LOC,0,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,0,INOFST,8) - INOFST = INOFST + 8 -C BYTES 29-34 6 CHAR BULLETIN NAME TTAAII - LOC(29:34) = TTAAII(1:6) -C -C IF ON ASCII COMPUTER, CONVERT LAST 6 CHARACTERS TO EBCDIC -C - IF (.NOT.IBM370) CALL W3AI39(LOC(29:29),6) -C - INOFST = INOFST + 48 -C BYTES 35-38 KWBX -C - LOC(35:38) = KWBX(1:4) -C -C IF ON ASCII COMPUTER, CONVERT LAST 4 CHARACTERS TO EBCDIC -C - IF (.NOT.IBM370) CALL W3AI39(LOC(35:35),4) - INOFST = INOFST + 32 -C BYTES 39-40 HR/MIN TIME OF BULLETIN CREATION -C TWO BYTES AS 4 BIT BCD - KA = KARY(3) / 1000 - KB = MOD(KARY(3),1000) / 100 - KC = MOD(KARY(3),100) / 10 - KD = MOD(KARY(3),10) - CALL SBYTE (LOC,KA,INOFST,4) - INOFST = INOFST + 4 - CALL SBYTE (LOC,KB,INOFST,4) - INOFST = INOFST + 4 - CALL SBYTE (LOC,KC,INOFST,4) - INOFST = INOFST + 4 - CALL SBYTE (LOC,KD,INOFST,4) - INOFST = INOFST + 4 -C BYTES 41-45 CATALOG NUMBER ELSE (SET TO 55555) - IF (KARY(4).GE.1.AND.KARY(4).LE.99999) THEN - CALL W3AI15 (KARY(4),IHOLD,1,8,'-') - IF (LW.EQ.4) THEN - CALL SBYTE (LOC,IHOLD(1),INOFST,8) - INOFST = INOFST + 8 - CALL SBYTE (LOC,IHOLD(2),INOFST,32) - INOFST = INOFST + 32 -C -C ON CRAY 64 BIT COMPUTER -C - ELSE - CALL SBYTE (LOC,IHOLD,INOFST,40) - INOFST = INOFST + 40 - END IF -C -C IF ON ASCII COMPUTER, CONVERT LAST 5 CHARACTERS TO EBCDIC -C - IF (.NOT.IBM370) CALL W3AI39(LOC(41:41),5) - ELSE - CALL SBYTE (LOC,-168430091,INOFST,32) - INOFST = INOFST + 32 - CALL SBYTE (LOC,245,INOFST,8) - INOFST = INOFST + 8 - END IF -C BYTES 46-80 INTEGER ZEROES - DO 4676 I = 1, 8 - CALL SBYTE (LOC,0,INOFST,32) - INOFST = INOFST + 32 - 4676 CONTINUE - CALL SBYTE (LOC,0,INOFST,24) - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fp11.f b/external/w3nco/v2.0.6/src/w3fp11.f deleted file mode 100644 index c33ec4a2b..000000000 --- a/external/w3nco/v2.0.6/src/w3fp11.f +++ /dev/null @@ -1,845 +0,0 @@ - SUBROUTINE W3FP11 (IPDS0, IPDS, TITL, IERR) -C SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FP11 ONE-LINE GRIB TITLER FROM PDS SECTION -C PRGMMR: MCCLEES ORG: NMC421 DATE:88-02-02 -C -C ABSTRACT: CONVERTS GRIB FORMATTED PRODUCT DEFINITION SECTION VERSION -C 1 TO A ONE LINE READABLE TITLE. GRIB SECTION 0 IS ALSO TESTED TO -C VERIFY THAT GRIB DATA IS BEING DECIPHERED. -C -C PROGRAM HISTORY LOG: -C 91-06-19 R.E.JONES -C 92-05-29 R.E.JONES ADD WATER TEMP TO TABLES -C 93-01-19 R.E.JONES ADD MONTGOMARY STREAM FUNCTION TO TABLES -C ADD CODE FOR SURFACE VALUE 113. -C ADD CONDENSATION PRESSURE TO TABLES -C 93-02-19 R.E.JONES ADD CAPE AND TKE (157 & 158) TO TABLES -C 93-02-24 R.E.JONES ADD GRIB TYPE PMSLE (130) TO TABLES -C 93-03-26 R.E.JONES ADD GRIB TYPE SGLYR (175) TO TABLES -C 93-03-27 R.E.JONES CHANGES FOR REVISED O.N.388 MAR. 3,1993 -C 93-03-29 R.E.JONES ADD SAVE STATEMENT -C 93-04-16 R.E.JONES ADD GRIB TYPE LAT, LON (176,177) TO TABLES -C 93-04-25 R.E.JONES ADD GRIB TYPE 204, 205, 211, 212, 218 -C 93-05-18 R.E.JONES ADD TEST FOR MODEL 70 -C 93-06-26 R.E.JONES ADD GRIB TYPE 128, 129, TAKE OUT TEST FOR -C MODEL 86. -C 93-08-07 R.E.JONES ADD GRIB TYPE 156 (CIN), 150 (CBMZW), -C 151 (CBTZW), 152 (CBTMW) TO TABLES. -C 93-10-14 R.E.JONES CHANGE FOR O.N. 388 REV. OCT. 8,1993 -C 93-10-29 R.E.JONES CHANGE FOR 'L CDC' 'M CDC' 'H CDC' -C 93-10-14 R.E.JONES CHANGE FOR O.N. 388 REV. NOV. 19,1993 -C 94-02-05 R.E.JONES CHANGE FOR O.N. 388 REV. DEC. 14,1993 -C ADD MODEL NUMBER 86 AND 87. -C 94-03-24 R.E.JONES ADD GRIB TYPE 24 (TOTO3), 206 (UVPI) -C 94-06-04 R.E.JONES CHANGE UVPI TO UVI -C 94-06-16 R.E.JONES ADD GRIB TYPE 144,145,146,147,148,149 -C SOILW,PEVPR,CWORK,U-GWD,V-GWD,PV TO TABLES. -C 94-06-22 R.E.JONES ADD NCAR (60) TO CENTERS -C 94-07-25 R.E.JONES CORRECTION FOR 71, 72, 213 (T CDC), (CDCON), -C (CDLYR) -C 94-10-27 R.E.JONES ADD GRIB TYPE 191 (PROB), 192 (PROBN), ADD -C TEST FOR MODEL 90, 91, 92, 93, ADD SUB -C CENTER 2. -C 95-02-09 R.E.JONES CORRECTION FOR CENTURY FOR FNOC -C 95-04-11 R.E.JONES CORRECTION FOR LMH AND LMV -C 95-06-20 R.E.JONES ADD GRIB TYPE 189 (VSTM), 190 (HLCY), 193 -C (POP), 194 (CPOFP), 195 (CPOZP), 196 -C (USTM), 197 (VSTM) TO TABLES. -C 95-08-07 R.E.JONES ADD GRIB TYPE 153 (CLWMR), 154 (O3MR), 221 -C (HPBL), 237 (O3TOT). -C 95-09-07 R.E.JONES TAKE OUT GRIB TYPE 24 (TOTO3), CHANGE TO -C GRIB TYPE 10 (TOZNE). ADD LEVEL 117, -C POTENTIAL VORTITICITY (pv) LEVEL, ADD ETA -C LEVEL 119, ADD 120 LAYER BETWWEN TWO ETA -C LEVELS. CHANGE NAME OF LEVEL 107 TO (SIGL), -C CHANGE NAME OF LEVEL 108 TO (SIGY). -C 95-09-26 R.E.JONES ADD LEVEL 204 (HTFL) HIGHEST TROPSPHERE -C FREEZING LEVEL. -C 95-10-19 R.E.JONES CHANGE SOME OF THE LEVEL ABREVIATIONS. -C 95-12-13 R.E.JONES ADD 8 SUB-CENTERS TO TABLES -C 96-03-04 R.E.JONES CHANGES FOR O.N. 388 JAN 2, 1996 -C 96-03-22 R.E.JONES CHANGE SCUSF TO CSUSF -C 96-10-01 IREDELL RECOGNIZE FORECAST TIME UNITS 1 TO 12 -C AND CORRECT FOR YEAR 2000 -C 96-10-31 R.E.JONES CHANGE ARRAY AND TABLE FOR ICS1 TO 10. -C 96-10-01 IREDELL ALLOW PARAMETER TABLE VERSION UP TO 127 -C 98-05-26 Gilbert ADDED 17 NEW PARAMETERS ( GRIB TABLE 2 ) -C ADDED 6 NEW SPECIAL LEVELS FOR CLOUDS -C ADDED SUBCENTER 11 (TDL) UNDER CENTER 7 (NCEP) -C 98-12-21 Gilbert REPLACED FUNCTION ICHAR WITH MOVA2I. -C 01-01-05 VUONG ADD LEVEL 247 (EHLT) EQUILIBRIUM LEVEL -C 02-05-01 VUONG CHANGES FOR O.N. 388 MAR 21, 2002 -C 02-03-25 VUONG ADD GRIB TABLE VERSION 129 AND 130 -C 03-07-02 Gilbert Added 5 new params to Table version 129 -C 04-14-04 VUONG ADD GRIB TABLE VERSION 131 AND ADDED 12 -C NEW PARAMETER TO TABLE VERSION 129 -C 04-08-09 VUONG ADD PARAMETER (THFLX) TO TABLE VERSION 129 -C 05-02-08 COOKE CORRECTED ENTRY FOR FREEZING RAIN, CRFZR TO -C CFRZR IN THE HHNAM1 ARRAY -C 06-08-11 VUONG ADD LEVELS (235,236,237,238,240,245) AND ADDED -C NEW PARAMETERS TO TABLE VERSION 129 AND ADDED -C ONE PARAMETER 154 TO TABLE VERSION 130 AND -C ADDED TABLE VERSION 128 -C 07-04-05 VUONG ADD PARAMETERS TO TABLE VERSION 128, 129 AND 130 -C 07-05-15 VUONG ADDED TIME RANGE INDICATOR 51 AND NEW TABLE 140 -C -C USAGE: CALL W3FP11 (IPDS0, IPDS, TITL, IERR ) -C INPUT ARGUMENT LIST: -C IPDS0 - GRIB SECTION 0 READ AS CHARACTER*8 -C IPDS - GRIB PDS SECTION READ AS CHARACTER*28 -C -C OUTPUT ARGUMENT LIST: -C TITL - CHARACTER*86 OUTPUT PRINT LINE -C IERR 0 - COMPLETED SATISFACTORILY -C 1 - GRIB SECTION 0, CAN NOT FIND 'GRIB' -C 2 - GRIB IS NOT VERSION 1 -C 3 - LENGTH OF PDS SECTION IS LESS THAN 28 -C 4 - COULD NOT MATCH TYPE INDICATOR -C 5 - COULD NOT MATCH TYPE LEVEL -C 6 - COULD NOT INTERPRET ORIGINATOR OF CODE -C 7 - COULD NOT INTERPRET SUB CENTER 7 ORIGINATOR OF CODE -C 8 - COULD NOT INTERPRET SUB CENTER 9 ORIGINATOR OF CODE -C 9 - PARAMETER TABLE VERSION NOT 1 OR 2 -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM RS/6000 -C - INTEGER CENTER(17) - INTEGER SCNTR1(16) - INTEGER SCNTR2(14) - INTEGER FCSTIM - INTEGER HH(252) - INTEGER HH1(105) - INTEGER HH2(105) - INTEGER HH3(42) - INTEGER HH128(72) - INTEGER HH129(98) - INTEGER HH130(112) - INTEGER HH131(241) - INTEGER HH140(112) - INTEGER HHH(73) - INTEGER IERR - INTEGER P1 - INTEGER P2 - INTEGER TIMERG -C - CHARACTER * 6 HHNAM(252) - CHARACTER * 6 HHNAM1(105) - CHARACTER * 6 HHNAM2(105) - CHARACTER * 6 HHNAM3(42) - CHARACTER * 6 HHNAM128(72) - CHARACTER * 6 HHNAM129(98) - CHARACTER * 6 HHNAM130(112) - CHARACTER * 6 HHNAM140(112) - CHARACTER * 6 HHNAM131(241) - CHARACTER * 4 HHHNAM(73) - CHARACTER * (*) IPDS - CHARACTER * 8 IPDS0 - CHARACTER * 28 IDPDS - CHARACTER * 4 GRIB - CHARACTER * 28 KNAM1(17) - CHARACTER * 28 KNAM2(16) - CHARACTER * 28 KNAM3(14) - CHARACTER * 3 MONTH(12) - CHARACTER * 4 TIMUN(12) - CHARACTER * 2 TIMUN1(12) - CHARACTER * 86 TITL -C - EQUIVALENCE (HH(1),HH1(1)) - EQUIVALENCE (HH(106),HH2(1)) - EQUIVALENCE (HH(211),HH3(1)) - EQUIVALENCE (HHNAM(1),HHNAM1(1)) - EQUIVALENCE (HHNAM(106),HHNAM2(1)) - EQUIVALENCE (HHNAM(211),HHNAM3(1)) -C - SAVE -C - DATA CENTER/ 7, 8, 9, 34, 52, 54, 57, - & 58, 59, 60, 61, 62, 74, 85, - & 97, 98, 99/ -C -C TABLE 3 - TYPE AND VALUE OF LEVELS (PDS OCTETS 10, 11 AND 12) -C - DATA HHH / 1, 2, 3, 4, 5, 6, 7, - & 8, 9, 20, 100, 101, 102, 103, - & 104, 105, 106, 107, 108, 109, 110, - & 111, 112, 113, 114, 115, 116, 117, - & 119, 120, 121, 125, 126, 128, 141, - & 160, 200, 201, 204, 212, 213, 214, - & 222, 223, 224, 232, 233, 234, 209, - & 210, 211, 242, 243, 244, 246, 247, - & 206, 207, 248, 249, 251, 252, 235, - & 236, 237, 238, 215, 220, 239, 240, - & 245, 253, 254/ - DATA HHHNAM/'SFC ','CBL ','CTL ','0DEG','ADCL','MWSL','TRO ', - & 'NTAT','SEAB','TMPL','ISBL','ISBY','MSL ','GPML', - & 'GPMY','HTGL','HTGY','SIGL','SIGY','HYBL','HYBY', - & 'DBLL','DBLY','THEL','THEY','SPDL','SPDY','PVL ', - & 'ETAL','ETAY','IBYH','HGLH','ISBP','SGYH','IBYM', - & 'DBSL','EATM','EOCN','HTFL','LCBL','LCTL','LCY ', - & 'MCBL','MCTL','MCY ','HCBL','HCTL','HCY ','BCBL', - & 'BCTL','BCY ','CCBL','CCTL','CCY ','MTHE','EHLT', - & 'GCBL','GCTL','SCBL','SCTL','DCBL','DCTL','OITL', - & 'OLYR','OBML','OBIL','CEIL','PBLR','S26C','OMXL', - & 'LLTW','LBLS','HTLS'/ -C -C GRIB TABLE VERSION 2 (PDS OCTET 4 = 2) -C - DATA HH1 / - & 1, 2, 3, 5, 6, 7, 8, - & 9, 10, 11, 12, 13, 14, 15, - & 16, 17, 18, 19, 20, 21, 22, - & 23, 24, 25, 26, 27, 28, 29, - & 30, 31, 32, 33, 34, 35, 36, - & 37, 38, 39, 40, 41, 42, 43, - & 44, 45, 46, 47, 48, 49, 50, - & 51, 52, 53, 54, 55, 56, 57, - & 58, 59, 60, 61, 62, 63, 64, - & 65, 66, 67, 68, 69, 70, 71, - & 72, 73, 74, 75, 76, 77, 78, - & 79, 80, 81, 82, 83, 84, 85, - & 86, 87, 88, 89, 90, 91, 92, - & 93, 94, 95, 96, 97, 98, 99, - & 100, 101, 102, 103, 104, 105, 106/ - DATA HH2 / - & 107, 108, 109, 110, 111, 112, 113, - & 114, 115, 116, 117, 121, 122, 123, - & 124, 125, 126, 127, 128, 129, 130, - & 131, 132, 133, 134, 135, 136, 137, - & 138, 139, 140, 141, 142, 143, 144, - & 145, 146, 147, 148, 149, 150, 151, - & 152, 153, 154, 155, 156, 157, 158, - & 159, 160, 161, 162, 163, 164, 165, - & 166, 167, 168, 169, 172, 173, 174, - & 175, 176, 177, 181, 182, 183, 184, - & 189, 190, 191, 192, 193, 194, 195, - & 196, 197, 201, 204, 205, 206, 207, - & 208, 209, 211, 212, 213, 214, 215, - & 216, 217, 218, 219, 220 ,221, 222, - & 223, 226, 227, 228, 229, 231, 232/ - DATA HH3 / - & 233, 234, 235, 237, 238, 239, 241, - & 242, 243, 244, 245, 246, 247, 248, - & 249, 250, 251, 252, 253, 254, 255, - & 4, 118, 119, 120, 170, 171, 178, - & 179, 185, 186, 187, 198, 199, 200, - & 224, 225, 230, 180, 202, 210, 240/ - DATA HHNAM1/ - &' PRES ',' PRMSL',' PTEND',' ICAHT',' GP ',' HGT ',' DIST ', - &' HSTDV',' TOZNE',' TMP ',' VTMP ',' POT ',' EPOT ',' T MAX', - &' T MIN',' DPT ',' DEPR ',' LAPR ',' VIS ',' RDSP1',' RDSP2', - &' RDSP3',' PLI ',' TMP A',' PRESA',' GP A ',' WVSP1',' WVSP2', - &' WVSP3',' WDIR ',' WIND ',' U GRD',' V GRD',' STRM ',' V POT', - &' MNTSF',' SGCVV',' V VEL',' DZDT ',' ABS V',' ABS D',' REL V', - &' REL D',' VUCSH',' VVCSH',' DIR C',' SP C ',' UOGRD',' VOGRD', - &' SPF H',' R H ',' MIXR ',' P WAT',' VAPP ',' SAT D',' EVP ', - &' C ICE',' PRATE',' TSTM ',' A PCP',' NCPCP',' ACPCP',' SRWEQ', - &' WEASD',' SNO D',' MIXHT',' TTHDP',' MTHD ',' MTH A',' T CDC', - &' CDCON',' L CDC',' M CDC',' H CDC',' C WAT',' BLI ',' SNO C', - &' SNO L',' WTMP ',' LAND ',' DSL M',' SFC R',' ALBDO',' TSOIL', - &' SOILM',' VEG ',' SALTY',' DEN ',' WATR ',' ICE C',' ICETK', - &' DICED',' SICED',' U ICE',' V ICE',' ICE G',' ICE D',' SNO M', - &' HTSGW',' WVDIR',' WVHGT',' WVPER',' SWDIR',' SWELL',' SWPER'/ - DATA HHNAM2/ - &' DIRPW',' PERPW',' DIRSW',' PERSW',' NSWRS',' NLWRS',' NSWRT', - &' NLWRT',' LWAVR',' SWAVR',' G RAD',' LHTFL',' SHTFL',' BLYDP', - &' U FLX',' V FLX',' WMIXE',' IMG D',' MSLSA',' MSLMA',' MSLET', - &' LFT X',' 4LFTX',' K X ',' S X ',' MCONV',' VW SH',' TSLSA', - &' BVF2 ',' PV MW',' CRAIN',' CFRZR',' CICEP',' CSNOW',' SOILW', - &' PEVPR',' CWORK',' U-GWD',' V-GWD',' PV ',' COVMZ',' COVTZ', - &' COVTM',' CLWMR',' O3MR ',' GFLUX',' CIN ',' CAPE ',' TKE ', - &' CONDP',' CSUSF',' CSDSF',' CSULF',' CSDLF',' CFNSF',' CFNLF', - &' VBDSF',' VDDSF',' NBDSF',' NDDSF',' M FLX',' LMH ',' LMV ', - &' MLYNO',' NLAT ',' ELON ',' LPS X',' LPS Y',' HGT X',' HGT Y', - &' VPTMP',' HLCY ',' PROB ',' PROBN',' POP ',' CPOFP',' CPOZP', - &' USTM ',' VSTM ',' ICWAT',' DSWRF',' DLWRF',' UVI ',' MSTAV', - &' SFEXC',' MIXLY',' USWRF',' ULWRF',' CDLYR',' CPRAT',' TTDIA', - &' TTRAD',' TTPHY',' PREIX',' TSD1D',' NLGSP',' HPBL ',' 5WAVH', - &' CNWAT',' BMIXL',' AMIXL',' PEVAP',' SNOHF',' MFLUX',' DTRF '/ - DATA HHNAM3/ - &' UTRF ',' BGRUN',' SSRUN',' O3TOT',' SNOWC',' SNO T',' LRGHR', - &' CNVHR',' CNVMR',' SHAHR',' SHAMR',' VDFHR',' VDFUA',' VDFVA', - &' VDFMR',' SWHR ',' LWHR ',' CD ',' FRICV',' RI ',' MISS ', - &' PVORT',' BRTMP',' LWRAD',' SWRAD',' RWMR ',' SNMR ',' ICMR ', - &' GRMR ',' TURB ',' ICNG ',' LTNG ',' NCIP ',' EVBS ',' EVCW ', - &' SOTYP',' VGTYP',' 5WAVA',' GUST ',' CWDI ',' TRANS',' COVTW'/ -C -C GRIB TABLE VERSION 128 (PDS OCTET 4 = 128) -C ( OCEANGRAPHIC PARAMETER ) -C - DATA HH128/ - & 128, 129, 130, 131, 132, 133, 134, - & 135, 136, 137, 138, 139, 140, 141, - & 142, 143, 144, 145, 146, 147, 148, - & 149, 150, 151, 152, 153, 154, 155, - & 156, 157, 158, 159, 160, 161, 162, - & 163, 164, 165, 166, 167, 168, 169, - & 170, 171, 172, 173, 174, 175, 176, - & 177, 178, 179, 180, 181, 182, 183, - & 184, 185, 186, 187, 188, 189, 190, - & 191, 192, 193, 194, 254, 40, 41, - & 42, 43/ - DATA HHNAM128/ - &'ADEPTH',' DEPTH',' ELEV ','MXEL24','MNEL24',' ',' ', - &' O2 ',' PO4 ',' NO3 ',' SIO4 ',' CO2AQ',' HCO3 ',' CO3 ', - &' TCO2 ',' TALK ',' ',' ',' S11 ',' S12 ',' S22 ', - &' INV1 ',' INV2 ',' ',' ',' ',' ',' WVRGH', - &'WVSTRS',' WHITE','SWDIRW','SWFREW',' WVAGE','PWVAGE',' ', - &' ',' ',' LTURB',' ',' ',' ',' ', - &'AIHFLX','AOHFLX','IOHFLX','IOSFLX',' ',' OMLT ',' OMLS ', - &'P2OMLT',' OMLU ',' OMLV ',' ASHFL',' ASSFL',' BOTLD',' UBARO', - &' VBARO',' INTFD',' WTMPC',' SALIN',' EMNP ',' ',' KENG ', - &' ',' LAYTH',' SSTT ',' SSST ',' ','A RAIN','A SNOW', - &'A ICE ','A FRZR'/ -C -C GRIB TABLE VERSION 129 (PDS OCTET 4 = 129) -C - DATA HH129/ - & 128, 129, 130, 131, 132, 133, 134, - & 135, 136, 137, 138, 139, 140, 141, - & 142, 143, 144, 145, 146, 147, 148, - & 149, 150, 151, 152, 153, 154, 155, - & 156, 157, 158, 159, 160, 161, 162, - & 163, 164, 165, 166, 167, 168, 169, - & 170, 171, 172, 173, 174, 175, 176, - & 177, 178, 179, 180, 181, 182, 183, - & 184, 185, 186, 187, 188, 189, 190, - & 191, 192, 193, 194, 195, 196, 197, - & 198, 199, 200, 201, 201, 203, 204, - & 205, 206, 207, 208, 209, 210, 211, - & 212, 213, 214, 215, 216, 217, 218, - & 219, 220, 221, 222, 223, 224, 225/ - DATA HHNAM129/ - &' PAOT ',' PAOP ',' ',' FRAIN',' FICE ',' FRIME',' CUEFI', - &' TCOND',' TCOLW',' TCOLI',' TCOLR',' TCOLS',' TCOLC',' PLPL ', - &' HLPL ',' CEMS ',' COPD ',' PSIZ ',' TCWAT',' TCICE',' WDIF ', - &' WSTP ',' PTAN ',' PTNN ',' PTBN ',' PPAN ',' PPNN ',' PPBN ', - &' PMTC ',' PMTF ',' AETMP',' AEDPT',' AESPH',' AEUWD',' AEVWD', - &' LPMTF',' LIPMF',' REFZR',' REFZI',' REFZC',' TCLSW',' TCOLM', - &' ELRDI',' TSEC ',' TSECA',' NUM ',' AEPRS',' ICSEV',' ICPRB', - &' LAVNI',' HAVNI',' FLGHT',' OZCON',' OZCAT',' VEDH ',' SIGV ', - &' EWGT ',' CICEL',' CIVIS',' CIFLT',' LAVV ',' LOVV ',' USCT ', - &' VSCT ',' LAUV ',' LOUV ',' TCHP ',' DBSS ',' ODHA ',' OHC ', - &' SSHG ',' SLTFL',' DUVB ',' CDUVB',' THFLX',' UVAR ',' VVAR ', - &'UVVCC ',' MCLS ',' LAPP ',' LOPP ',' ',' REFO ',' REFD ', - &' REFC ','SBT122','SBT123','SBT124','SBT125',' MINRH',' MAXRH', - &' CEIL ','PBLREG',' ',' ',' ',' ',' '/ -C -C GRIB TABLE VERSION 130 (PDS OCTET 4 = 130) -C ( FOR LAND MODELING AND LAND DATA ASSIMILATION ) -C - DATA HH130/ - & 144, 145, 146, 147, 148, 149, 150, - & 151, 152, 153, 154, 155, 156, 157, - & 158, 159, 160, 161, 162, 163, 164, - & 165, 166, 167, 168, 169, 170, 171, - & 172, 173, 174, 175, 176, 177, 178, - & 179, 180, 181, 182, 183, 184, 185, - & 186, 187, 188, 189, 190, 191, 192, - & 193, 194, 195, 196, 197, 198, 199, - & 200, 201, 202, 203, 204, 205, 206, - & 207, 208, 209, 210, 211, 212, 213, - & 214, 215, 216, 217, 218, 219, 220, - & 221, 222, 223, 224, 225, 226, 227, - & 228, 229, 230, 231, 232, 233, 234, - & 235, 236, 237, 238, 239, 240, 241, - & 242, 243, 244, 245, 246, 247, 248, - & 249, 250, 251, 252, 253, 254, 255/ - DATA HHNAM130/ - &' SOIL ',' PEVPR',' VEGT ',' BARET',' AVSFT',' RADT ',' SSTOR', - &' LSOIL',' EWATR',' ',' LSPA ',' GFLUX',' CIN ',' CAPE ', - &' TKE ','MXSALB',' SOILL',' ASNOW',' ARAIN',' GWREC',' QREC ', - &' SNOWT',' VBDSF',' VDDSF',' NBDSF',' NDDSF','SNFALB',' ', - &' M FLX',' ',' ',' ',' NLAT ',' ELON ','FLDCAP', - &' ACOND',' SNOAG',' CCOND',' LAI ',' SFCRH',' SALBD',' ', - &' ',' NDVI ',' DRIP ','VBSLAB','VWSALB','NBSALB','NWSALB', - &' ',' ',' ',' ',' ',' SBSNO',' EVBS ', - &' EVCW ',' ',' ',' RSMIN',' DSWRF',' DLWRF',' ', - &' MSTAV',' SFEXC',' ',' TRANS',' USWRF',' ULWRF',' ', - &' ',' ',' ',' ',' ',' WILT ',' FLDCP', - &' HPBL ',' SLTYP',' CNWAT',' SOTYP',' VGTYP',' BMIXL',' AMIXL', - &' PEVAP',' SNOHF',' SMREF',' SMDRY',' ',' ',' BGRUN', - &' SSRUN',' ',' ',' SNOWC',' SNOT ',' POROS',' ', - &' ',' ',' ',' ',' RCS ',' RCT ',' RCQ ', - &' RCSOL',' ',' ',' CD ',' FRICV',' RI ',' '/ -C -C GRIB TABLE VERSION 140 (PDS OCTET 4 = 140) -C ( FOR WORLD AREA FORECAST SYSTEM (WAF/ICAO) -C - DATA HH140/ - & 144, 145, 146, 147, 148, 149, 150, - & 151, 152, 153, 154, 155, 156, 157, - & 158, 159, 160, 161, 162, 163, 164, - & 165, 166, 167, 168, 169, 170, 171, - & 172, 173, 174, 175, 176, 177, 178, - & 179, 180, 181, 182, 183, 184, 185, - & 186, 187, 188, 189, 190, 191, 192, - & 193, 194, 195, 196, 197, 198, 199, - & 200, 201, 202, 203, 204, 205, 206, - & 207, 208, 209, 210, 211, 212, 213, - & 214, 215, 216, 217, 218, 219, 220, - & 221, 222, 223, 224, 225, 226, 227, - & 228, 229, 230, 231, 232, 233, 234, - & 235, 236, 237, 238, 239, 240, 241, - & 242, 243, 244, 245, 246, 247, 248, - & 249, 250, 251, 252, 253, 254, 255/ - DATA HHNAM140/ - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' MEIP ',' MAIP ',' MECTP',' MACTP', - &' MECAT',' MACAT',' CBHE ',' PCBB ',' PCBT ',' PECBB',' PECBT', - &' HCBB ',' HCBT ',' HECBB',' HECBT',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' ', - &' ',' ',' ',' ',' ',' ',' MISS '/ -C -C GRIB TABLE VERSION 131 (PDS OCTET 4 = 131) -C - DATA HH131/ - & 1, 2, 3, 4, 5, 6, 7, - & 8, 9, 10, 11, 12, 13, 14, - & 15, 16, 17, 18, 19, 20, 21, - & 22, 23, 24, 25, 26, 27, 28, - & 29, 30, 31, 32, 33, 34, 35, - & 36, 37, 38, 39, 40, 41, 42, - & 43, 44, 45, 46, 47, 48, 49, - & 50, 51, 52, 53, 54, 55, 56, - & 57, 58, 59, 60, 61, 62, 63, - & 64, 65, 66, 67, 68, 69, 70, - & 71, 72, 73, 74, 75, 76, 77, - & 78, 79, 80, 81, 82, 83, 84, - & 85, 86, 87, 88, 89, 90, 91, - & 92, 93, 94, 95, 96, 97, 98, - & 99, 100, 101, 102, 103, 104, 105, - & 106, 107, 108, 109, 110, 111, 112, - & 113, 114, 115, 116, 117, 118, 119, - & 120, 121, 122, 123, 124, 125, 126, - & 127, 128, 130, 131, 132, 134, 135, - & 136, 139, 140, 141, 142, 143, 144, - & 145, 146, 147, 148, 149, 150, 151, - & 152, 153, 155, 156, 157, 158, 159, - & 160, 161, 162, 163, 164, 165, 166, - & 167, 168, 169, 170, 171, 172, 173, - & 174, 175, 176, 177, 178, 179, 180, - & 181, 182, 183, 184, 187, 188, 189, - & 190, 191, 192, 194, 196, 197, 198, - & 199, 200, 202, 203, 204, 205, 206, - & 207, 208, 210, 211, 212, 213, 214, - & 216, 218, 219, 220, 221, 222, 223, - & 224, 225, 226, 227, 228, 229, 230, - & 231, 232, 233, 234, 235, 237, 238, - & 239, 240, 241, 242, 243, 244, 245, - & 246, 247, 248, 249, 250, 251, 252, - & 253, 254, 255/ - DATA HHNAM131/ - &' PRES ',' PRMSL',' PTEND',' PVORT',' ICAHT',' GP ',' HGT ', - &' DIST ',' HSTDV',' TOZNE',' TMP ',' VTMP ',' POT ',' EPOT ', - &' TMAX ',' TMIN ',' DPT ',' DEPR ',' LAPR ',' VIS ',' RDSP1', - &' RDSP2',' RDSP3',' PLI ',' TMPA ',' PRESA',' GPA ',' WVSP1', - &' WVSP2',' WVSP3',' WDIR ',' WIND ',' UGRD ',' VGRD ',' STRM ', - &' VPOT ',' MNTSF',' SGVCC',' VVEL ',' DZDT ',' ABSV ',' ABSD ', - &' RELV ',' RELD ',' VUCSH',' VVCSH',' DIRC ',' SPC ',' UOGRD', - &' VOGRD',' SPFH ',' RH ',' MIXR ',' PWAT ',' VAPP ',' SATD ', - &' EVP ',' CICE ',' PRATE',' TSTM ',' APCP ',' NCPCP',' ACPCP', - &' SRWEQ',' WEASD',' SNOD ',' MIXHT',' TTHDP',' MTHD ',' MTHA ', - &' TCDC ',' CDCON',' LCDC ',' MCDC ',' HCDC ',' CWAT ',' BLI ', - &' SNOC ',' SNOL ',' WTMP ',' LAND ',' DSLM ',' SFCR ',' ALBDO', - &' TSOIL',' SOILM',' VEG ',' SALTY',' DEN ',' WATR ',' ICEC ', - &' ICETK',' DICED',' SICED',' UICE ',' VICE ',' ICEG ',' ICED ', - &' SNOM ',' HTSGW',' WVDIR',' WVHGT',' WVPER',' SWDIR',' SWELL', - &' SWPER',' DIRPW',' PERPW',' DIRSW',' PERSW',' NSWRS',' NLWRS', - &' NSWRT',' NLWRT',' LWAVR',' SWAVR',' GRAD ',' BRTMP',' LWRAD', - &' SWRAT',' LHTFL',' SHTFL',' BLYDP',' UFLX ',' VFLX ',' WMIXE', - &' IMGD ',' MSLSA',' MSLET',' LFTX ',' 4LFTX',' PRESN',' MCONV', - &' VWSH ',' PVMW ',' CRAIN',' CFRZR',' CICEP',' CSNOW',' SOILW', - &' PEVPR',' VEGT ',' BARET',' AVSFT',' RADT ',' SSTOR',' LSOIL', - &' EWATR',' CLWMR',' GFLUX',' CIN ',' CAPE ',' TKE ','MXSALB', - &' SOILL',' ASNOW',' ARAIN',' GWREC',' QREC ',' SNOWT',' VBDSF', - &' VDDSF',' NBDSF',' NDDSF','SNFALB',' RLYRS',' FLX ',' LMH ', - &' LMV ',' MLYNO',' NLAT ',' ELON ',' ICMR ',' ACOND',' SNOAG', - &' CCOND',' LAI ',' SFCRH',' SALBD',' NDVI ',' DRIP ',' LANDN', - &' HLCY ',' NLATN',' ELONN',' CPOFP',' USTM ',' VSTM ',' SBSNO', - &' EVBS ',' EVCW ',' APCPN',' RSMIN',' DSWRF',' DLWRF','ACPCPN', - &' MSTAV',' SFEXC',' TRANS',' USWRF',' ULWRF',' CDLYR',' CPRAT', - &' TTRAD',' HGTN ',' WILT ',' FLDCP',' HPBL ',' SLTYP',' CNWAT', - &' SOTYP',' VGTYP',' BMIXL',' AMIXL',' PEVAP',' SNOHF',' SMREF', - &' SMDRY',' WVINC',' WCINC',' BGRUN',' SSRUN','MVCONV',' SNOWC', - &' SNOT ',' POROS','WCCONV','WVUFLX','WVVFLX','WCUFLX','WCVFLX', - &' RCS ',' RCT ',' RCQ ',' RCSOL',' SWHR ',' LWHR ',' CD ', - &' FRICV',' RI ',' MISS '/ -C -C ONE LINE CHANGE FOR HDS (IBM370) (ASCII NAME GRIB IN HEX) -C -C DATA GRIB /Z47524942/ -C -C ONE LINE CHANGE FOR CRAY AND WORKSTATIONS -C - DATA GRIB /'GRIB'/ -C -C TABLE O (PDS OCTET 5) NATIONAL/INTERNATIONAL -C ORIGINATING CENTERS -C - DATA KNAM1 / - & ' US NWS - NCEP (WMC) ',' US NWS - NWSTG (WMC) ', - & ' US NWS - Other (WMC)',' JMA - Tokyo (RSMC) ', - & ' TPC (NHC),Miami(RSMC)',' CMS - Montreal (RSMC)', - & ' U.S. Air Force - GWC ',' U.S. Navy - FNOC ', - & ' NOAA FSL, Boulder, CO',' NCAR, Boulder, CO ', - & ' SARGO, Landover, MD ',' US Naval, Oceanograph', - & ' U.K Met. Office RSMC)',' French WS - Toulouse ', - & ' European Space Agency',' ECMWF (RSMC) ', - & ' De Bilt, Netherlands '/ -C -C TABLE C (PDS OCTET 26) NATIONAL SUB-CENTERS -C - DATA KNAM2 / - & ' NCEP RE-ANALYSIS PRO.',' NCEP ENSEMBLE PRODUCT', - & ' NCEP CENTRAL OPS. ',' ENV. MODELING CENTER ', - & ' HYDRO. PRED. CENTER ',' OCEAN PRED. CENTER ', - & ' CLIMATE PRED. CENTER ',' AVIATION WEATHER CEN.', - & ' STORM PRED. CENTER ',' TROPICAL PRED. CENTER', - & ' NWS TECH. DEV. LAB. ',' NESDIS OFF. RES. APP.', - & ' FAA ',' NWS MET. DEV. LAB. ', - & ' NARR PROJECT ',' SPACE ENV. CENTER '/ - DATA KNAM3 / - & ' ABRFC TULSA, OK ',' AKRFC ANCHORAGE, AK ', - & ' CBRFC SALT LAKE, UT ',' CNRFC SACRAMENTO, CA', - & ' LMRFC SLIDEL, LA. ',' MARFC STATE CO., PA ', - & ' MBRFC KANSAS CITY MO',' NCRFC MINNEAPOLIS MN', - & ' NERFC HARTFORD, CT. ',' NWRFC PORTLAND, OR ', - & ' OHRFC CINCINNATI, OH',' SERFC ATLANTA, GA ', - & ' WGRFC FORT WORTH, TX',' OUN NORMAN OK WFO '/ - DATA MONTH /'JAN','FEB','MAR','APR','MAY','JUN', - & 'JUL','AUG','SEP','OCT','NOV','DEC'/ - DATA SCNTR1/ 1, 2, 3, 4, 5, 6, 7, - & 8, 9, 10, 11, 12, 13, 14, - & 15, 16/ - DATA SCNTR2/ 150, 151, 152, 153, 154, 155, 156, - & 157, 158, 159, 160, 161, 162, 170/ - DATA TIMUN /'HRS.','DAYS','MOS.','YRS.','DECS','NORM','CENS', - & 2*'----','3HRS','6HRS','HDYS'/ - DATA TIMUN1/'HR','DY','MO','YR','DC','NO','CN', - & 2*'--','3H','6H','HD'/ -C -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C -C 1.0 INITIALIZATION - NO. OF ENTRIES IN INDCATOR PARM. -C - NO. OF ENTRIES IN TYPE LEVEL -C - NO. OF ENTRIES IN CNTR PROD. DTA. -C - NO. OF ENTRIES IN SUB CNTR1 PROD. DTA. -C - NO. OF ENTRIES IN SUB CNTR2 PROD. DTA. -C - IQ = 252 - IS = 73 - IC = 17 - IH128 = 72 - IH129 = 98 - IH130 = 112 - IH140 = 112 - IH131 = 241 - ICS1 = 16 - ICS2 = 14 - IERR = 0 -C - TITL(1:30) = ' ' - TITL(31:60) = ' ' - TITL(61:86) = ' ' -C -C --------------------------------------------------------------------- -C 2.0 TEST SECTION 0 FOR ASCII 'GRIB' -C - IF (GRIB(1:4) .NE. IPDS0(1:4)) THEN - IERR = 1 - RETURN - ENDIF -C -C TEST SECTION 0 FOR GRIB VERSION 1 -C - IF (MOVA2I(IPDS0(8:8)).NE.1) THEN - IERR = 2 - RETURN - END IF -C -C TEST THE LENGTH OF THE PDS (SECTION 1) -C - LENPDS = MOVA2I(IPDS(1:1)) * 65536 + MOVA2I(IPDS(2:2)) * 256 + - & MOVA2I(IPDS(3:3)) - IF (LENPDS.GE.28) THEN - IDPDS(1:28) = IPDS(1:28) - ELSE - IERR = 3 - RETURN - ENDIF -C -C TEST PDS (OCTET 4) FOR PARAMETER TABLE VERSION -C NUMBER 1 OR 2 OR 128, 129 OR 130 OR 131 OR 140 -C - IVER = MOVA2I(IDPDS(4:4)) - IF (IVER.GT.131) THEN - IERR = 9 - RETURN - END IF -C -C 4.0 FIND THE INDICATOR AND TYPE LEVELS -C - IQQ = MOVA2I (IDPDS(9:9)) - IF (IVER.EQ.128) THEN - DO K = 1, IH128 - IF (IQQ .EQ. HH128(K)) THEN - TITL(21:27) = HHNAM128(K) - GO TO 150 - END IF - END DO - ELSE IF (IVER.EQ.129) THEN - DO K = 1, IH129 - IF (IQQ .EQ. HH129(K)) THEN - TITL(21:27) = HHNAM129(K) - GO TO 150 - END IF - END DO - ELSE IF (IVER.EQ.130) THEN - DO K = 1, IH130 - IF (IQQ .EQ. HH130(K)) THEN - TITL(21:27) = HHNAM130(K) - GO TO 150 - END IF - END DO - ELSE IF (IVER.EQ.131) THEN - DO K = 1, IH131 - IF (IQQ .EQ. HH131(K)) THEN - TITL(21:27) = HHNAM131(K) - GO TO 150 - END IF - END DO - ELSE IF (IVER.EQ.140) THEN - DO K = 1, IH140 - IF (IQQ .EQ. HH140(K)) THEN - TITL(21:27) = HHNAM140(K) - GO TO 150 - END IF - END DO - ELSE - DO II = 1,IQ - IF (IQQ .EQ. HH(II)) GO TO 100 - END DO - IF (IQQ.EQ.77.AND.IVER.EQ.1) GO TO 100 - IF (IQQ.EQ.24) GO TO 100 - IERR = 4 - RETURN - END IF -C - 100 CONTINUE - IF (IQQ .NE. 77 .AND. IQQ .NE. 24) THEN - TITL(21:27) = HHNAM(II) - ELSE IF (IQQ .EQ. 77) THEN - TITL(21:27) = ' CONDP ' -C -C TAKE OUT AFTER ALL PROGRAMS ARE CHANGED THAT USE 24 -C FOR TOTAL OZONE. -C - ELSE IF (IQQ .EQ. 24) THEN - TITL(21:27) = ' TOTO3 ' - END IF - IF (IQQ.EQ.137.AND.IVER.EQ.1) TITL(21:27) = ' VISIB ' - 150 CONTINUE - ISS = MOVA2I (IDPDS(10:10)) -C -C CORRECTION FOR 'NLAT' 'ELON' 'L CDC' 'M CDC', 'H CDC', -C 'T CDC' -C - IF (ISS.EQ.0.AND.(IQQ.EQ.176.OR.IQQ.EQ.177. - & OR.IQQ.EQ.71.OR.IQQ.EQ.73.OR.IQQ.EQ.74. - & OR.IQQ.EQ.72.OR.IQQ.EQ.75.OR.IQQ.EQ.213. - & OR.IQQ.EQ.173.OR.IQQ.EQ.174)) THEN - GO TO 300 - END IF - DO JJ = 1,IS - IF (ISS .EQ. HHH(JJ)) GO TO 200 - END DO - IERR = 5 - RETURN -C - 200 CONTINUE - IF (ISS.EQ.4.OR.ISS.EQ.5.OR.ISS.EQ.20.OR.ISS.EQ.100.OR. - & ISS.EQ.103.OR.ISS.EQ.105.OR.ISS.EQ.107.OR.ISS.EQ.109.OR. - & ISS.EQ.111.OR.ISS.EQ.113.OR.ISS.EQ.115.OR.ISS.EQ.117.OR. - & ISS.EQ.119.OR.ISS.EQ.125.OR.ISS.EQ.126.OR.ISS.EQ.160.OR. - & ISS.EQ.236)THEN - TITL(16:20) = HHHNAM(JJ) - LEVEL = MOVA2I(IDPDS(11:11)) * 256 + MOVA2I(IDPDS(12:12)) - IF (ISS.EQ.107.OR.ISS.EQ.119) THEN - ALEVEL = FLOAT(LEVEL) / 10000.0 - WRITE (TITL(9:15),FMT='(F6.4)') ALEVEL - ELSE IF (ISS.EQ.5) THEN -C DO NOTHING - ELSE - WRITE (TITL(11:15),FMT='(I4)') LEVEL - END IF - ELSE IF (ISS.EQ.1.OR.ISS.EQ.6.OR.ISS.EQ.7.OR.ISS.EQ.8.OR. - & ISS.EQ.9 .OR.ISS.EQ.102.OR.ISS.EQ.200.OR.ISS.EQ.201.OR. - & ISS.EQ.204.OR.ISS.EQ.212.OR.ISS.EQ.213.OR.ISS.EQ.214.OR. - & ISS.EQ.222.OR.ISS.EQ.223.OR.ISS.EQ.224.OR.ISS.EQ.232.OR. - & ISS.EQ.233.OR.ISS.EQ.234.OR.ISS.EQ.209.OR.ISS.EQ.210.OR. - & ISS.EQ.211.OR.ISS.EQ.242.OR.ISS.EQ.243.OR.ISS.EQ.244.OR. - & ISS.EQ.245.OR.ISS.EQ.235.OR.ISS.EQ.237.OR.ISS.EQ.238.OR. - & ISS.EQ.246.OR.ISS.EQ.247.OR.ISS.EQ.206.OR.ISS.EQ.207.OR. - & ISS.EQ.248.OR.ISS.EQ.249.OR.ISS.EQ.251.OR.ISS.EQ.252) THEN - TITL(16:20) = HHHNAM(JJ) - TITL(1:4) = ' ' - TITL(11:15) = ' ' - ELSE IF (ISS.EQ.101.OR.ISS.EQ.104.OR.ISS.EQ.106.OR.ISS.EQ.108. - & OR.ISS.EQ.110.OR.ISS.EQ.112.OR.ISS.EQ.114.OR.ISS.EQ.116.OR. - & ISS.EQ.120.OR.ISS.EQ.121.OR.ISS.EQ.128.OR.ISS.EQ.141) THEN - TITL(6:11) = HHHNAM(JJ) - TITL(16:20) = HHHNAM(JJ) - ITEMP = MOVA2I(IDPDS(11:11)) - WRITE (UNIT=TITL(1:4),FMT='(I4)') ITEMP - JTEMP = MOVA2I(IDPDS(12:12)) - WRITE (UNIT=TITL(11:15),FMT='(I4)') JTEMP - END IF -C -C 5.0 INSERT THE YEAR,DAY,MONTH AND TIME -C - 300 CONTINUE - IHR = MOVA2I (IDPDS(16:16)) - IDAY = MOVA2I (IDPDS(15:15)) - IMON = MOVA2I (IDPDS(14:14)) - IYR = MOVA2I (IDPDS(13:13)) - ICEN = MOVA2I (IDPDS(25:25)) -C -C SUBTRACT 1 FROM CENTURY TO MAKE 4 DIGIT YEAR -C - ICEN = ICEN - 1 -C - IYR = ICEN * 100 + IYR - WRITE (UNIT=TITL(59:62),FMT='(I4)') IYR - WRITE (UNIT=TITL(52:53),FMT='(I2)') IDAY - WRITE (UNIT=TITL(38:49),FMT='(A6,I2.2,A2)') 'AFTER ',IHR,'Z ' - TITL(55:57) = MONTH(IMON) - FCSTIM = MOVA2I (IDPDS(18:18)) - TITL(34:36) = TIMUN(FCSTIM) - P1 = MOVA2I(IDPDS(19:19)) - P2 = MOVA2I(IDPDS(20:20)) - TIMERG = MOVA2I(IDPDS(21:21)) - IF (TIMERG.EQ.10) THEN - P1 = P1 * 256 + P2 - P2 = 0 - END IF -C -C ADD CORRECTION IF BYTE 21 (TIME RANGE) IS 2 -C - IF (TIMERG.EQ.2) THEN - TITL(4:20) = TITL(11:27) - TITL(21:21) = ' ' - WRITE (UNIT=TITL(22:24),FMT='(I3)') P1 - TITL(25:28) = ' TO ' - WRITE (UNIT=TITL(29:32),FMT='(I3)') P2 -C -C PRECIP AMOUNTS -C - ELSE IF (TIMERG.EQ.4) THEN - WRITE (UNIT=TITL(29:32),FMT='(I3)') P2 - MTEMP = P2 - P1 - WRITE (UNIT=TITL(2:4),FMT='(I3)') MTEMP - TITL(6:7) = TIMUN1(FCSTIM) - TITL(8:12) = ' ACUM' -C -C AVERAGE -C - ELSE IF (TIMERG.EQ.3) THEN - WRITE (UNIT=TITL(29:32),FMT='(I3)') P2 - MTEMP = P2 - P1 - WRITE (UNIT=TITL(2:4),FMT='(I3)') MTEMP - TITL(6:7) = TIMUN1(FCSTIM) - TITL(8:12) = ' AVG' -C -C CLIMATOLOGICAL MEAN VALUE -C - ELSE IF (TIMERG.EQ.51) THEN - WRITE (UNIT=TITL(29:32),FMT='(I3)') P2 - MTEMP = P2 - P1 - WRITE (UNIT=TITL(2:4),FMT='(I3)') MTEMP - TITL(6:7) = TIMUN1(FCSTIM) - TITL(8:12) = ' AVG' - ELSE - WRITE (UNIT=TITL(29:32),FMT='(I3)') P1 - ENDIF -C -C TEST FOR ANALYSIS (MAKE CORRECTION IF MODEL IS ANALYSIS) -C - IF (TIMERG.EQ.0.AND.P1.EQ.0) THEN - TITL(29:42) = ' ANALYSIS VT ' - MODEL = MOVA2I(IDPDS(6:6)) - IF (MODEL.EQ.10.OR.MODEL.EQ.39.OR.MODEL.EQ.45.OR. - & MODEL.EQ.53.OR.MODEL.EQ.68.OR.MODEL.EQ.69.OR. - & MODEL.EQ.70.OR.MODEL.EQ.73.OR.MODEL.EQ.74.OR. - & MODEL.EQ.75.OR.MODEL.EQ.76.OR.MODEL.EQ.77.OR. - & MODEL.EQ.78.OR.MODEL.EQ.79.OR.MODEL.EQ.80.OR. - & MODEL.EQ.83.OR.MODEL.EQ.84.OR.MODEL.EQ.85.OR. - & MODEL.EQ.86.OR.MODEL.EQ.87.OR.MODEL.EQ.88.OR. - & MODEL.EQ.90.OR.MODEL.EQ.91.OR.MODEL.EQ.92.OR. - & MODEL.EQ.105.OR.MODEL.EQ.110.OR.MODEL.EQ.150.OR. - & MODEL.EQ.151) THEN - TITL(29:42) = ' 00-HR FCST ' - ENDIF - ENDIF -C -C TEST FOR 00-HR FCST (INITIALIZED ANALYSIS) -C - IF (TIMERG.EQ.1.AND.P1.EQ.0) THEN - TITL(29:42) = ' 00-HR FCST ' - ENDIF -C -C 3.0 FIND WHO GENERATED THE CODE -C CHECK FOR SUB-CENTERS -C - IGENC = MOVA2I (IDPDS(5:5)) - ISUBC = MOVA2I (IDPDS(26:26)) -C -C TEST FOR SUB-CENTERS WHEN CENTER IS 7 -C - - IF (ISUBC.NE.0.AND.IGENC.EQ.7) THEN - DO J = 1,ICS1 - IF (ISUBC .EQ. SCNTR1(J)) THEN - TITL(63:86) = KNAM2(J) - RETURN - END IF - END DO - IERR = 7 - END IF -C -C TEST FOR SUB-CENTERS WHEN CENTER IS 9 -C - IF (ISUBC.NE.0.AND.IGENC.EQ.9) THEN - DO J = 1,ICS2 - IF (ISUBC .EQ. SCNTR2(J)) THEN - TITL(63:86) = KNAM3(J) - RETURN - END IF - END DO - IERR = 8 - END IF -C -C TEST TO SEE IF CENTER IN TABLES -C - DO I = 1,IC - IF (IGENC .EQ. CENTER(I)) THEN - TITL(63:86) = KNAM1(I) - RETURN - END IF - END DO -C - IERR = 6 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fp12.f b/external/w3nco/v2.0.6/src/w3fp12.f deleted file mode 100644 index 152b92c28..000000000 --- a/external/w3nco/v2.0.6/src/w3fp12.f +++ /dev/null @@ -1,612 +0,0 @@ - SUBROUTINE W3FP12(ID8, IFLAG, IDPDS, ICENT, ISCALE, IER) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FP12 CREATES THE PRODUCT DEFINITION SECTION -C PRGMMR: MCCLEES ORG: NMC421 DATE:92-01-14 -C -C ABSTRACT: FORMATS THE PRODUCT DEFINITION SECTION ACCORDING TO THE -C SPECIFICATIONS SET BY WMO. USING O.N. 84 ID'S (1ST 8 WORDS) -C AS THE INPUT DATA. NEW SUBROUTINE CORRESPONDS TO THE REVISION -C #1 OF THE WMO GRIB STANDARDS MADE MARCH 15, 1991. -C -C PROGRAM HISTORY LOG: -C 91-07-30 MCCLEES,A.J. NEW SUBROUTINE WHICH FORMATS THE PDS -C SECTION FROM THE O.N. 84 ID'S FROM THE GRIB -C EDITION 1 DATED MARCH 15, 1991. -C -C 92-01-06 MCCLEES,A.J. DELETE PARAMATER 202 (ACCUMULATED EVAP) -C AND MAKE PARAMETER 57 (EVAPORATION) THE -C EQUIVALENT OF O.N.84 117. -C 92-11-02 R.E.JONES CORRECTION AT SAME LEVEL AS W3FP12 IN -C V77W3LIB ON HDS 92-09-30 -C 93-03-29 R.E.JONES ADD SAVE STATEMENT -C 93-04-16 R.E.JONES ADD 176, 177 LAT, LON TO TABLES -C 93-08-03 R.E.JONES ADD 156 (CIN), 204 (DSWRF), 205 (DLWRF) -C 211 (USWRF), 212 (ULWRF) TO TABLES -C 95-02-07 R.E.JONES CHANGE PDS BYTE 4, VERSION NUMBER TO 2. -C 95-07-14 R.E.JONES CORRECTION FOR SFC LFT X -C 98-03-10 B. VUONG REMOVE THE CDIR$ INTEGER=64 DIRECTIVE -C 98-12-21 Gilbert Replaced Function ICHAR with mova2i. -C 99-02-15 B. FACEY REPLACE W3FS04 WITH W3MOVDAT. -C 1999-03-15 Gilbert Specified 8-byte integer array explicitly for ID8 -C 99-03-22 B. FACEY REMOVE THE DATE RECALCULATION FOR MEAN -C CHARTS. THIS INCLUDES THE PREVIOUS -C CHANGE TO W3MOVDAT. -C -C USAGE: CALL W3FP12 (ID8, IFLAG, IDPDS, ICENT, ISCALE, IER) -C INPUT ARGUMENT LIST: -C ID8 - FIRST 8 ID WORKDS (O.N.84) INTEGER*4 -C ICENT - CENTURY, 2 DIGITS, FOR 1991 IT IS 20. -C IFLAG - INDICATION OF INCLUSION OR OMISSION OF GRID DEFINITION -C AND/OR BIT MAP CODE CHARACTER*1 -C ISCALE - 10 SCALER INTEGER*4 -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C IDPDS - GRIB PRODUCT DEFINITION SECTION CHARACTER*1 (28) -C IER = 0 COMPLETED SMOOTHLY -C = 1 INDICATOR PARAMETER N.A. TO GRIB -C = 2 LEVEL INDICATOR N.A. TO GRIB -C = 3 TIME RANGE N.A. TO GRIB NOTATION -C = 4 LAYERS OR LEVELS N.A. TO GRIB -C OUTPUT FILES: -C FT06F001 - SELF-EXPLANATORY ERROR MESSAGES -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -C - INTEGER E1 - INTEGER E2 - INTEGER F1 - INTEGER F2 - DATA F1/0/, F2/0/ - INTEGER HH (163) - INTEGER(8) ID8 ( 4) - INTEGER(8) IDWK ( 4) - INTEGER(8) MSK1,MSK2,MSK3,MSK4,MSK5,MSK6,MSK7 - INTEGER ISIGN - INTEGER ISCALE - INTEGER ICENT - INTEGER LL (163) - INTEGER L - INTEGER M - INTEGER N - INTEGER Q - INTEGER S1 - INTEGER T - DATA T/0/ -C - CHARACTER*1 IDPDS (28) - CHARACTER*1 IFLAG - CHARACTER*1 IHOLD ( 8) - CHARACTER*1 IPDS1 ( 8) - CHARACTER*1 KDATE ( 8) - CHARACTER*1 LIDWK (32) -C - EQUIVALENCE (IDWK(1),LIDWK(1)) - EQUIVALENCE (L,IPDS1(1)) - EQUIVALENCE (NBYTES,IHOLD(1)) - EQUIVALENCE (JDATE,KDATE(1)) - REAL RINC(5) - INTEGER NDATE(8), MDATE(8) -C - DATA LL / 8, 8, 9, 255, 255, 255, 1, 6, 255, 255, - & 16, 24, 19, 23, 20, 21, 17, 18, 255, 180, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 55, 50, 48, 56, 49, 57, 80, 81, 71, 255, - & 40, 42, 72, 74, 73, 255, 255, 255, 255, 255, - & 304, 305, 95, 88, 101, 89, 104, 255, 117, 255, - & 97, 98, 90, 105, 94, 255, 255, 93, 188, 255, - & 255, 255, 255, 211, 255, 255, 255, 255, 255, 255, - & 255, 384, 161, 255, 255, 169, 22, 255, 255, 255, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 255, 400, 389, 385, 388, 391, 386, 390, 402, 401, - & 404, 403, 204, 255, 255, 255, 255, 255, 255, 255, - & 255, 255, 195, 194, 255, 255, 255, 255, 255, 255, - & 255, 255, 112, 116, 114, 255, 103, 52, 255, 255, - & 255, 255, 119, 157, 158, 159, 255, 176, 177, 392, - & 192, 190, 199, 216, 189, 193, 191, 210, 198, 255, - & 255, 1, 255/ - DATA HH / 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, - & 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, - & 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, - & 31, 32, 33, 33, 34, 34, 35, 36, 37, 38, - & 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, - & 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, - & 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, - & 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, - & 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, - & 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, - & 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, - & 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, - & 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, - & 129, 130, 131, 132, 133, 134, 135, 136, 137, 150, - & 151, 152, 156, 157, 158, 159, 175, 176, 177, 201, - & 204, 205, 207, 208, 209, 211, 212, 213, 216, 218, - & 220, 222, 255/ -C DATA MSK1 /Z'00000FFF'/, -C & MSK2 /Z'0FFFFF00'/, -C & MSK3 /Z'0000007F'/, -C & MSK4 /Z'00000080'/, -C & MSK5 /Z'F0000000'/, -C & MSK6 /Z'00000200'/, -C & MSK7 /Z'000000FF'/ -C CHANGE HEX TO DECIMAL TO MAKE SUBROUTINE MORE PORTABLE - DATA MSK1 /4095/, - & MSK2 /268435200/, - & MSK3 /127/, - & MSK4 /128/, - & MSK5 /Z'00000000F0000000'/ - & MSK6 /512/, - & MSK7 /255/ -C -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -C -C 1.0 INITIALIZATION - NO. OF ENTRIES IN INDCATOR PARM. -C - NO. OF ENTRIES IN TYPE LEVEL -C - IQ = 163 -C -C 1.1 COPY O.N. 84 ID'S INTO WORK SPACE -C - DO 100 N = 1,4 - IDWK(N) = ID8(N) - 100 CONTINUE -C --------------------------------------------------------------------- -C 2.0 NO. OF OCTETS IN THE PDS IN THE FIRST 3 -C 2.1 SET CNTR ID, DATA TYPE, GRID DEF AND FLAG -C - NBYTES = 28 - IDPDS(1) = IHOLD(6) - IDPDS(2) = IHOLD(7) - IDPDS(3) = IHOLD(8) - IDPDS(4) = CHAR(2) - IDPDS(5) = CHAR(7) - IDPDS(6) = LIDWK(30) - JSCALE = ISCALE - IF (JSCALE.LT.0) THEN - JSCALE = -JSCALE - IDPDS(27) = CHAR(128) - IDPDS(28) = CHAR(JSCALE) - ELSE - IDPDS(27) = CHAR(0) - IDPDS(28) = CHAR(JSCALE) - END IF -C - IF (LIDWK(30) .EQ. CHAR (69)) THEN - IF (LIDWK(29) .EQ. CHAR(3)) THEN - IDPDS(6) = CHAR(68) - ELSE IF (LIDWK(29) .EQ. CHAR(4)) THEN - IDPDS(6) = CHAR(69) - ENDIF - ENDIF - IF (LIDWK(30) .EQ. CHAR (78)) THEN - IF (LIDWK(29) .EQ. CHAR(3)) THEN - IDPDS(6) = CHAR(77) - ELSE IF (LIDWK(29) .EQ. CHAR(4)) THEN - IDPDS(6) = CHAR(78) - ENDIF - ENDIF - IDPDS(7) = LIDWK(20) - IF (LIDWK(20) .EQ. CHAR (26)) IDPDS(7) = CHAR(6) - IDPDS(8) = IFLAG - IDPDS(24) = CHAR(0) - IDPDS(26) = CHAR(0) -C--------------------------------------------------------------------- -C -C 3.0 FORM INDICATOR PARAMETER -C - Q = ISHFT(IDWK(1),-52_8) - DO 300 I = 1,IQ - II = I - IF (Q .EQ. LL(I)) GO TO 310 - 300 CONTINUE -C - IER = 1 - PRINT 320, IER, Q, ID8 - 320 FORMAT (' W3FP12 (320) - IER = ',I2,', Q = ',I3,/, - & ' OFFICE NOTE 84 PARAMETER N.A. IN GRIB', - & /,1X,4(Z16,' ')) - RETURN -C - 310 I = II - S1 = IAND(ISHFT(IDWK(1),-40_8),MSK1) - C1 = ISHFT(IAND(IDWK(1),MSK2),-8_8) - ISIG1 = IAND(IDWK(1),MSK4) - E1 = IAND(IDWK(1),MSK3) - IF (ISIG1 .NE. 0) E1 = -E1 - M = ISHFT(IAND(ISHFT(IDWK(2),-32_8),MSK5),-28_8) - N = ISHFT(IAND(IDWK(2),MSK5),-28_8) - KS = ISHFT(IAND(ISHFT(IDWK(3),-32_8),MSK6),-8_8) - IF (M.NE.0) THEN - C2 = ISHFT(IAND(IDWK(2),MSK2),-8_8) - ISIG2 = IAND(IDWK(2),MSK4) - E2 = IAND(IDWK(2),MSK3) - IF (ISIG2 .NE. 0) E2 = -E2 - ENDIF - IDPDS(9) = CHAR(HH(I)) -C -C N IS A SPECIAL TEST FOR WAVE HGTS, M AND KS ARE SPECIAL FOR -C ACCUMULATED PRECIP -C - IF (N .EQ. 5 .AND. Q .EQ. 1) THEN - IDPDS(9) = CHAR (222) - ENDIF - IF (KS .EQ. 2) THEN - IF (M .EQ. 0 .AND. Q .EQ. 8) THEN - IDPDS(9) = CHAR (211) - END IF -C - IF (M .EQ. 0 .AND. Q .EQ. 1) THEN - IDPDS(9) = CHAR (210) - ENDIF -C - IF (M .EQ. 1 .AND. Q .EQ. 1) THEN - IER = 1 - PRINT 330, IER, ID8 - 330 FORMAT (' W3FP12 (330) - IER =',I2,/, - & ' OFFICE NOTE 84 PARAMETER N.A. IN GRIB', - & /,1X,4(Z16,' ')) - RETURN - ENDIF - ENDIF -C -C 4.0 DETERMINE IF LAYERS OR LEVEL AND FORM TYPE -C -C ......... M = THE M MARKER FROM O.N.84 CHECK ABOVE -C ......... S1 = S1 TYPE OF SURFACE -C - IF (M .EQ. 0) THEN - IF (S1.EQ.0.AND.(Q.EQ.176.OR.Q.EQ.177)) THEN - IDPDS(10) = CHAR(0) - IDPDS(11) = CHAR(0) - IDPDS(12) = CHAR(0) -C - ELSE IF (S1 .EQ. 8) THEN - IDPDS(10) = CHAR (100) - L = C1 * (10. ** E1) + .5 - IDPDS(11) = IPDS1(7) - IDPDS(12) = IPDS1(8) -C - ELSE IF (S1 .EQ. 1) THEN - IDPDS(10) = CHAR (103) - L = C1 * (10. ** E1) + .5 - IDPDS(11) = IPDS1(7) - IDPDS(12) = IPDS1(8) -C - ELSE IF (S1 .EQ. 6) THEN - IDPDS(10) = CHAR (105) - L = C1 * (10. ** E1) + .5 - IDPDS(11) = IPDS1(7) - IDPDS(12) = IPDS1(8) -C - ELSE IF (S1 .EQ. 7) THEN - IDPDS(10) = CHAR (111) -C CONVERT FROM METERS TO CENTIMETERS - IF (ISIG1 .NE. 0) E1 = E1 + 2 - L = C1 * (10. ** E1) + .5 - IDPDS(11) = IPDS1(7) - IDPDS(12) = IPDS1(8) -C - ELSE IF (S1.EQ.148 .OR. S1 .EQ. 144 .OR. S1 .EQ. 145) THEN - IDPDS(10) = CHAR (107) - L = (C1 * (10. ** E1) * 10**4) + .5 - IDPDS(11) = IPDS1(7) - IDPDS(12) = IPDS1(8) -C - ELSE IF (S1 .EQ. 16) THEN - L = C1 * (10. ** E1) + .5 - IF (L .EQ. 273) THEN - IDPDS(10) = CHAR (4) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) - ELSE - IER = 2 - PRINT 410, IER, S1, ID8 - RETURN - ENDIF -C - ELSE IF (S1 .EQ. 19) THEN - L = C1 * (10. ** E1) + .5 - IDPDS(10) = CHAR (113) - IDPDS(11) = IPDS1(7) - IDPDS(12) = IPDS1(8) -C -C SET LEVEL AND PARAMETER FOR MSL PRESSURE -C - ELSE IF (S1 .EQ. 128) THEN - IF (Q.EQ.8) THEN - IDPDS(9) = CHAR(2) - END IF - IDPDS(10) = CHAR (102) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) -C - ELSE IF (S1 .EQ. 129) THEN - IDPDS(10) = CHAR (1) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) -C - ELSE IF (S1 .EQ. 130) THEN - IDPDS(10) = CHAR (7) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) -C - ELSE IF (S1 .EQ. 131) THEN - IDPDS(10) = CHAR (6) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) -C - ELSE IF (S1 .EQ. 133) THEN - IDPDS(10) = CHAR (1) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) -C - ELSE IF (S1 .EQ. 136) THEN - IF (Q.EQ.8) THEN - IF (T.EQ.2.AND.F1.EQ.0.AND.F2.EQ.3) THEN - IDPDS(9) = CHAR (137) - ELSE - IDPDS(9) = CHAR (128) - END IF - END IF - IDPDS(10) = CHAR (102) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) -C - ELSE IF (S1 .EQ. 137) THEN - IF (Q.EQ.8) THEN - IDPDS(9) = CHAR (129) - END IF - IDPDS(10) = CHAR (102) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) -C - ELSE IF (S1 .EQ. 138) THEN - IF (Q.EQ.8) THEN - IDPDS(9) = CHAR (130) - END IF - IDPDS(10) = CHAR (102) - IDPDS(11) = CHAR (0) - IDPDS(12) = CHAR (0) -C - ELSE - IER = 2 - PRINT 410, IER, S1, ID8 - 410 FORMAT (' W3FP12 (410) - IER = ',I2,', S1 = ',I5,/, - & ' SURFACE TYPE N.A. IN GRIB',/,' ID8 = ', - & 4(Z16,' ')) - RETURN - ENDIF -C - ELSE IF (M .EQ. 1) THEN - IF ((S1 .EQ. 8) .AND. (Q .EQ. 1)) THEN - IDPDS(9) = CHAR(101) - IDPDS(10) = CHAR(101) - JJJ = ((C1 * 10. ** E1) * .1) + .5 - IDPDS(11) = CHAR(JJJ) - KKK = ((C2 * 10. ** E2) * .1) + .5 - IDPDS(12) = CHAR(KKK) - END IF -C - ELSE IF (M .EQ. 2) THEN - IF (S1 .EQ. 8) THEN - IDPDS(10) = CHAR(101) - JJJ = ((C1 * 10. ** E1) * .1) + .5 - IDPDS(11) = CHAR(JJJ) - KKK = ((C2 * 10. ** E2) * .1) + .5 - IDPDS(12) = CHAR(KKK) - IF (IDPDS(9) .EQ. CHAR(131)) IDPDS(12) = CHAR(100) -C - ELSE IF (S1 .EQ. 1) THEN - IDPDS(10) = CHAR(104) - JJJ = ((C1 * 10. ** E1) * .1) + .5 - IDPDS(11) = CHAR(JJJ) - KKK = ((C2 * 10. ** E2) * .1) + .5 - IDPDS(12) = CHAR(KKK) -C - ELSE IF (S1 .EQ. 6) THEN - IDPDS(10) = CHAR(106) - JJJ = ((C1 * 10. ** E1) * .1) + .5 - IDPDS(11) = CHAR(JJJ) - KKK = ((C2 * 10. ** E2) * .1) + .5 - IDPDS(12) = CHAR(KKK) -C - ELSE IF (S1.EQ.148 .OR. S1 .EQ. 144 .OR. S1 .EQ. 145) THEN - IDPDS(10) = CHAR(108) - JJJ = ((C1 * 10. ** E1) * 10**2) + .5 - IDPDS(11) = CHAR(JJJ) - KKK = ((C2 * 10. ** E2) * 10**2) + .5 - IDPDS(12) = CHAR(KKK) -C - ELSE - IER = 2 - PRINT 420, IER, S1, ID8 - 420 FORMAT (' W3FP12 (420) - IER = ',I2,', S1 = ',I5,/, - & ' SURFACE LAYERS N.A. IN GRIB', - & /,' ID8= ',4(Z16,' ')) - RETURN - ENDIF - ELSE IF (M .GT. 2) THEN - IER = 4 - PRINT 500, IER, M, ID8 - 500 FORMAT ('W3FP12 (500) - IER = ',I2,', M = ',/, - & ' THE M FROM O.N. 84 N.A. IN GRIB', - & /,' ID8 = ',4(Z16,' ')) - RETURN - ENDIF -C -C 6.0 DATE - YR.,MO,DA,& INITIAL HR AND CENTURY -C - IDPDS(13) = LIDWK(25) - IDPDS(14) = LIDWK(26) - IDPDS(15) = LIDWK(27) - IDPDS(16) = LIDWK(28) - IDPDS(17) = CHAR(0) - IDPDS(25) = CHAR(ICENT) -C--------------------------------------------------------------------- -C -C OCTET (17) N.A. FROM O.N. 84 DATA -C -C 7.0 INDICATOR OF TIME UNIT, TIME RANGE 1 AND 2, AND TIME -C RANGE FLAG -C - T = ISHFT((IAND(IDWK(1),MSK5)),-28_8) - F1 = IAND(ISHFT(IDWK(1),-32_8),MSK7) - F2 = IAND(ISHFT(IDWK(2),-32_8),MSK7) - IF (T .EQ. 0) THEN - IDPDS(18) = CHAR (1) - IDPDS(19) = CHAR (F1) - IDPDS(20) = CHAR (0) - IDPDS(21) = CHAR (0) - IDPDS(22) = CHAR (0) - IDPDS(23) = CHAR (0) -C - ELSE IF (T .EQ. 1) THEN - PRINT 710, T, ID8 - IER = 3 - RETURN -C - ELSE IF (T .EQ. 2) THEN - IF (mova2i(IDPDS(9)).NE.137) THEN - PRINT 710, T, ID8 - IER = 3 - RETURN - END IF -C - ELSE IF (T .EQ. 3) THEN - IF (Q .EQ. 89 .OR. Q .EQ. 90 .OR. Q .EQ. 94 - & .OR. Q .EQ. 105) THEN -C - IDPDS(18) = CHAR (1) -C CORRECTION FOR 00 HR FCST - ITEMP = F1 - F2 - IF (ITEMP.LT.0) ITEMP = 0 -C IDPDS(19) = CHAR (F1 - F2) - IDPDS(19) = CHAR (ITEMP) - IDPDS(20) = CHAR (F1) - IDPDS(21) = CHAR (4) - IDPDS(22) = CHAR (0) - IDPDS(23) = CHAR (0) -C - ELSE - IDPDS(18) = CHAR (1) -C CORRECTION FOR 00 HR FCST - ITEMP = F1 - F2 - IF (ITEMP.LT.0) ITEMP = 0 -C IDPDS(19) = CHAR (F1 - F2) - IDPDS(19) = CHAR (ITEMP) - IDPDS(20) = CHAR (F1) - IDPDS(21) = CHAR (5) - IDPDS(22) = CHAR (0) - IDPDS(23) = CHAR (0) - END IF -C - ELSE IF (T .EQ. 4) THEN -C - IF (F1 .EQ. 0 .AND. F2 .NE. 0) THEN - IDPDS(18) = CHAR (4) - IDPDS(19) = CHAR (0) - IDPDS(20) = CHAR (1) - IDPDS(21) = CHAR (124) - L = F2 - IDPDS(22) = IPDS1(7) - IDPDS(23) = IPDS1(8) -C - ELSE IF (F1 .NE. 0 .AND. F2 .EQ. 0) THEN - IDPDS(18) = CHAR (2) - IDPDS(19) = CHAR (0) - IDPDS(20) = CHAR (1) - IDPDS(21) = CHAR (124) - L = F1 - IDPDS(22) = IPDS1(7) - IDPDS(23) = IPDS1(8) -C - ENDIF -C - ELSE IF (T .EQ. 5) THEN - IDPDS(18) = CHAR (1) -C CORRECTION FOR 00 HR FCST - ITEMP = F1 - F2 - IF (ITEMP.LT.0) ITEMP = 0 -C IDPDS(19) = CHAR (F1 - F2) - IDPDS(19) = CHAR (ITEMP) - IDPDS(20) = CHAR (F1) - IDPDS(21) = CHAR (2) - IDPDS(22) = CHAR (0) - IDPDS(23) = CHAR (0) -C - ELSE IF (T .EQ. 6) THEN - JSIGN = IAND(ISHFT(IDWK(1),-32_8),MSK4) - JSIGO = IAND(ISHFT(IDWK(2),-32_8),MSK4) - F1 = IAND(ISHFT(IDWK(1),-32_8),MSK3) - F2 = IAND(ISHFT(IDWK(2),-32_8),MSK3) - IF (JSIGN .NE. 0) F1 = -F1 - IF (JSIGO .NE. 0) F2 = -F2 - IDPDS(18) = CHAR (1) -C****CALCULATE NEW DATE BASED ON THE BEGINNING OF THE DATA IN MEAN -C INCR = (F1) -C IF (INCR.LT.0) THEN -C RINC=0 -C RINC(2)=INCR -C PRINT *, 'INCR=',INCR -C CALL W3FS04 (IDWK(4),JDATE,INCR,IERR) -C IYR=ICHAR(LIDWK(25)) -C PRINT *, 'IYR = ', IYR -C IF(IYR.LT.20)THEN -C MDATE(1)=2000+IYR -C ELSE -C MDATE(1)=1900+IYR -C ENDIF -C MDATE(2) = ICHAR(LIDWK(26)) -C MDATE(3) = ICHAR(LIDWK(27)) -C MDATE(4) = ICHAR(LIDWK(28)) -C PRINT *, 'CHANGE DATE BY - ', RINC(2) -C CALL W3MOVDAT(RINC,MDATE,NDATE) -C PRINT *,'NEW DATE =',NDATE(1),NDATE(2),NDATE(3),NDATE(5) -C IYEAR = MOD(NDATE(1),100) -C LIDWK(25) = CHAR(IYEAR) -C LIDWK(26) = CHAR(NDATE(2)) -C LIDWK(27) = CHAR(NDATE(3)) -C LIDWK(28) = CHAR(NDATE(4)) -C END IF - IDPDS(13) = LIDWK(25) - IDPDS(14) = LIDWK(26) - IDPDS(15) = LIDWK(27) - IDPDS(16) = LIDWK(28) - IF (F1.LT.0) THEN - IDPDS(19) = CHAR (0) - IDPDS(21) = CHAR (123) - ELSE - NF1 = F1 * 12 - IDPDS(19) = CHAR (NF1) - IDPDS(21) = CHAR (113) - END IF - IDPDS(20) = CHAR (24) -C*****THE NUMBER OF CASES AVERAGED IS ASSUMING ONE TIME A DAY -C L = (F2/2) + 1 -C***THE ABOVE CALCULATION WOULD BE CORR. IF ID8(3) WERE CORR. - L = (F2+1) / 2 - IDPDS(22) = IPDS1(7) - IDPDS(23) = IPDS1(8) -C - ELSE IF (T .EQ. 7) THEN - PRINT 710, T, ID8 - IER = 3 - RETURN -C - ELSE IF (T .EQ. 10) THEN - PRINT 710, T, ID8 - IER = 3 - RETURN -C - 710 FORMAT (' W3FP12 (710) - NOT APPLICABLE (YET) TO GRIB. ', - & ', T = ',I2,/, - & ' O.N. 84 IDS ARE ',/, - & 1X,4(Z16,' ')) -C - ENDIF - IER = 0 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fp13.f b/external/w3nco/v2.0.6/src/w3fp13.f deleted file mode 100644 index 45a77b7ef..000000000 --- a/external/w3nco/v2.0.6/src/w3fp13.f +++ /dev/null @@ -1,920 +0,0 @@ - SUBROUTINE W3FP13 (GRIB, PDS, ID8, IERR ) -C$$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FP13 CONVERT GRIB PDS EDITION 1 TO O.N. 84 ID -C PRGMMR: MCCLEES ORG: NMC421 DATE:91-10-07 -C -C ABSTRACT: CONVERTS GRIB VERSION 1 FORMATTED PRODUCT DEFINITION -C SECTION TO AN OFFICE NOTE 84 ID LABEL. FORMATS ALL THAT IS APPLI- -C CABLE IN THE FIRST 8 WORDS OF O.N. 84. (CAUTION ****SEE REMARKS) -C -C PROGRAM HISTORY LOG: -C 91-10-07 ORIGINAL AUTHOR MCCLEES, A. J. -C 92-01-06 R.E.JONES CONVERT TO SiliconGraphics 3.3 FORTRAN 77 -C 93-03-29 R.E.JONES ADD SAVE STATEMENT -C 94-04-17 R.E.JONES COMPLETE REWRITE TO USE SBYTE, MAKE CODE -C PORTABLE, UPGRADE TO ON388, MAR 24,1994 -C 94-05-05 R.E.JONES CORRECTION IN TWO TABLES -C 96-08-02 R.E.JONES ERROR USING T MARKER -C 96-09-03 R.E.JONES ADD MERCATOR GRIDS 8 AND 53 TO TABLES -C 99-02-15 B. FACEY REPLACE W3FS04 WITH W3MOVDAT. -C 02-10-15 VUONG REPLACED FUNCTION ICHAR WITH MOVA2I -C -C USAGE: CALL W3FP13 (GRIB, PDS, ID8, IERR ) -C INPUT ARGUMENT LIST: -C GRIB - GRIB SECTION 0 READ AS CHARACTER*8 -C PDS - GRIB PDS SECTION 1 READ AS CHARACTER*1 PDS(*) -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C ID8 - 12 INTEGER*4 FORMATTED O.N. 84 ID. -C 6 INTEGER 64 BIT WORDS ON CRAY -C IERR 0 - COMPLETED SATISFACTORILY -C 1 - GRIB BLOCK 0 NOT CORRECT -C 2 - LENGTH OF PDS NOT CORRECT -C 3 - COULD NOT MATCH TYPE INDICATOR -C 4 - GRID TYPE NOT IN TABLES -C 5 - COULD NOT MATCH TYPE LEVEL -C 6 - COULD NOT INTERPRET ORIGINATOR OF CODE -C SUBPROGRAMS CALLED: -C SPECIAL: INDEX, MOVA2I, CHAR, IOR, IAND, ISHFT -C -C LIBRARY: -C W3LIB: W3MOVDAT, W3FI69, W3FI01 -C -C REMARKS: SOME OF THE ID'S WILL NOT BE EXACT TO THE O.N. 84 -C FOR LOCATING FIELD ON THE DATASET. THESE DIFFERENCES -C ARE MAINLY DUE TO TRUNCATION ERRORS WITH LAYERS. -C FOR EXAMPLE: .18019 SIG .47191 SIG R H FOR 36.O HRS -C WILL CONVERT TO: .18000 SIG .47000 SIG R H FOR 36.0 HRS -C !!!!!!!THE ABOVE ID'S NOW FORCED TO BE EXACT!!!!!!!!! -C IF J THE WORD COUNT IS GREATER THEN 32743, J IS STORED -C IN THE 12TH ID WORD. BITS 16-31 OF THE 8TH ID WORD ARE -C SET TO ZERO. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C$$$ -C - INTEGER HH (255) - INTEGER HH1 (127) - INTEGER HH2 (128) - INTEGER LL (255) - INTEGER LL1 (127) - INTEGER LL2 (128) - INTEGER ICXG2 (9) - INTEGER ICXGB2 (9) - INTEGER ICXG1 (7) - INTEGER ICXGB1 (7) -C - INTEGER C1 - INTEGER C2 - INTEGER E1 - INTEGER E2 - INTEGER FTU - INTEGER F1 - INTEGER F2 - INTEGER ID (25) - INTEGER ID8 (12) - INTEGER IDATE - INTEGER JDATE - INTEGER IGEN ( 4) - INTEGER NGRD (34) - INTEGER NPTS (34) - INTEGER P1 - INTEGER P2 - INTEGER S1 -C INTEGER S2 - INTEGER T - INTEGER TR -C - CHARACTER * 8 GRIB - CHARACTER * 8 IGRIB - REAL RINC(5) - INTEGER NDATE(8), MDATE(8) - CHARACTER * 1 IWORK ( 8) - CHARACTER * 1 JWORK ( 8) - CHARACTER * 1 PDS ( *) -C - SAVE -C - EQUIVALENCE (HH(1),HH1(1)) - EQUIVALENCE (HH(128),HH2(1)) - EQUIVALENCE (LL(1),LL1(1)) - EQUIVALENCE (LL(128),LL2(1)) - EQUIVALENCE (IDATE,IWORK(1)) - EQUIVALENCE (JDATE,JWORK(1)) -C - DATA HH1 / 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, - & 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, - & 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, - & 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, - & 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, - & 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, - & 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, - & 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, - & 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - & 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, - & 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, - & 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, - & 121, 122, 123, 124, 125, 126, 127/ - DATA HH2 / 128, 129, 130, - & 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, - & 141, 142, 143, 144, 145, 146, 147, 148, 149, 150, - & 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, - & 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, - & 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, - & 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, - & 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, - & 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, - & 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, - & 221, 222, 223, 224, 225, 226, 227, 228, 229, 230, - & 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, - & 241, 242, 243, 244, 245, 246, 247, 248, 249, 250, - & 251, 252, 253, 254, 255/ -C - DATA IGEN / 7, 58, 66, 98/ -C -C ########### NUMBERS FORCED AFTER CONVERTING FROM GRIB LAYER. -C ICXG2 1.0000, .98230, .96470, -C .85000, .84368, .47191, -C .18017, .81573, .25011 -C ################# -C - DATA ICXG2 /Z'00002710', Z'00017FB6', Z'000178D6', - A Z'00014C08', Z'00014990', Z'0000B857', - A Z'00004663', Z'00013EA5', Z'000061B3'/ -C -C ########### NUMBERS CALCULATED BY GRIB LAYER. -C ICXGB2 1.00000, .98000, .96000, -C .85000, .84000, .47000, -C .18000, .82000, .25000 -C ################# -C - DATA ICXGB2/Z'00002710', Z'00017ED0', Z'00017700', - A Z'00014C00', Z'00014820', Z'0000B798', - A Z'00004650', Z'00014050', Z'000061A8'/ -C -C ########### NUMBERS FORCED AFTER CONVERTING FROM GRIB SINGLE. -C ICXG1 .98230, .89671, .78483 -C .94316, .84367, .999.00, .25011 -C ################# -C - DATA ICXG1 /Z'00017FB6', Z'00015E47', Z'00013293', - A Z'0001706C', Z'0001498F', Z'0000863C', Z'000061B3'/ -C -C ########### NUMBERS CALCULATED BY GRIB LAYER. -C ICXGB1 .98230, .89670, .78480 -C .94320, .84370, 998.00, .25000 -C ################# -C - DATA ICXGB1/Z'00017FB6', Z'00015E46', Z'00013290', - A Z'00017070', Z'00014992', Z'000185D8', Z'000061A8'/ -C - DATA LL1 / 8, 8, 9, 255, 255, 255, 1, 6, 255, 255, - & 16, 24, 19, 23, 20, 21, 17, 18, 255, 180, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 55, 50, 48, 49, 80, 81, 71, 255, 40, 42, - & 72, 74, 73, 255, 255, 255, 255, 255, 304, 305, - & 95, 88, 101, 89, 104, 255, 117, 255, 97, 98, - & 90, 105, 94, 255, 255, 93, 188, 255, 255, 255, - & 255, 211, 255, 255, 255, 255, 255, 255, 255, 384, - & 161, 255, 255, 169, 22, 255, 255, 255, 255, 255, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 400, - & 389, 385, 388, 391, 386, 390, 402, 401, 404, 403, - & 204, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 195, 194, 255, 255, 255, 255, 255/ - DATA LL2 / 255, 255, 255, - & 112, 116, 114, 255, 103, 52, 255, 255, 255, 255, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 255, 255, 255, 255, 255, 119, 157, 158, 159, 255, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 255, 255, 255, 255, 255, 176, 177, 255, 255, 255, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 392, 255, 255, 192, 190, 255, 199, 216, 189, 255, - & 193, 191, 210, 107, 255, 198, 255, 255, 255, 255, - & 255, 1, 255, 255, 255, 255, 255, 255, 255, 255, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - & 255, 160, 255, 255, 255/ -C - DATA NPTS / 1679, 259920, 3021, 2385, 5104, 4225, - & 4225, 5365, 5365, 8326, 8326, - & 5967, 6177, 6177, 12321, 12321, 12321, - & 32400, 32400, 5022, 12902, 25803, - & 24162, 48232, 18048, 6889, 10283, - & 3640, 16170, 6889, 19305, 11040, - & 72960, 6693/ -C - DATA NGRD / 1, 4, 5, 6, 8, 27, - & 28, 29, 30, 33, 34, - & 53, 55, 56, 75, 76, 77, - & 85, 86, 87, 90, 91, - & 92, 93, 98, 100, 101, - & 103, 104, 105, 106, 107, - & 126, 214/ -C -C DATA MSK1 /Z0000FFFF/, -C & MSK2 /Z00000080/, -C & MSK3 /Z00000000/, -C & MSK4 /Z00000200/ -C CHANGE HEX TO DECIMAL TO MAKE SUBROUTINE MORE PORTABLE -C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - DATA MSK1 /65535/, - & MSK2 /128/, - & MSK3 /0/, - & MSK4 /512/ -C -C MAKE SECTION 0, PUT 'GRIB' IN ASCII -C - IGRIB(1:1) = CHAR(71) - IGRIB(2:2) = CHAR(82) - IGRIB(3:3) = CHAR(73) - IGRIB(4:4) = CHAR(66) - IGRIB(5:5) = CHAR(0) - IGRIB(6:6) = CHAR(0) - IGRIB(7:7) = CHAR(0) - IGRIB(8:8) = CHAR(1) -C -C CONVERT PDS INTO 25 INTEGER NUMBERS -C - CALL W3FI69(PDS,ID) -C -C ID(1) = NUMBER OF BYTES IN PDS -C ID(2) = PARAMETER TABLE VERSION NUMBER -C ID(3) = IDENTIFICATION OF ORIGINATING CENTER -C ID(4) = MODEL IDENTIFICATION (ALLOCATED BY ORIGINATING CENTER) -C ID(5) = GRID IDENTIFICATION -C ID(6) = 0 IF NO GDS SECTION, 1 IF GDS SECTION IS INCLUDED -C ID(7) = 0 IF NO BMS SECTION, 1 IF BMS SECTION IS INCLUDED -C ID(8) = INDICATOR OF PARAMETER AND UNITS -C ID(9) = INDICATOR OF TYPE OF LEVEL OR LAYER -C ID(10) = LEVEL 1 -C ID(11) = LEVEL 2 -C ID(12) = YEAR OF CENTURY -C ID(13) = MONTH OF YEAR -C ID(14) = DAY OF MONTH -C ID(15) = HOUR OF DAY -C ID(16) = MINUTE OF HOUR (IN MOST CASES SET TO 0) -C ID(17) = FCST TIME UNIT -C ID(18) = P1 PERIOD OF TIME -C ID(19) = P2 PERIOD OF TIME -C ID(20) = TIME RANGE INDICATOR -C ID(21) = NUMBER INCLUDED IN AVERAGE -C ID(22) = NUMBER MISSING FROM AVERAGES OR ACCUMULATIONS -C ID(23) = CENTURY -C ID(24) = IDENTIFICATION OF SUB-CENTER (TABLE 0 - PART 2) -C ID(25) = SCALING POWER OF 10 -C -C THE 1ST 8 32 BIT WORDS WITH THE OFFICE NOTE 84 ID'S ARE -C IN 27 PARTS, SBYTE IS USED WITH BIT COUNTS TO MAKE THIS -C DATA. THIS MAKE IT WORD SIZE INDEPENDENT, AND MAKES THIS -C SUBROUTINE PORTABLE. TABLE WITH STARTING BITS IS NEXT. -C THE STARTING BIT AND NO. OF BITS IS USED AS THE 3RD AND -C 4TH PARAMETER FOR SBYTE. READ GBYTES DOCUMENT FROM NCAR -C FOR INFORMATION ABOUT SBYTE. SEE PAGE 38, FIGURE 1, IN -C OFFICE NOTE 84. -C -C NO. NAME STARTING BIT NO. OF BITS -C ----------------------------------------- -C 1 Q 0 12 -C 2 S1 12 12 -C 3 F1 24 8 -C 4 T 32 4 -C 5 C1 36 20 -C 6 E1 56 8 -C 7 M 64 4 -C 8 X 68 8 -C 9 S2 76 12 -C 10 F2 88 8 -C 11 N 96 4 -C 12 C2 100 20 -C 13 E2 120 8 -C 14 CD 128 8 -C 15 CM 136 8 -C 16 KS 144 8 -C 17 K 152 8 -C 18 GES 160 4 -C 19 164 12 -C 20 NW 176 16 -C 21 YY 192 8 -C 22 MM 200 8 -C 23 DD 208 8 -C 24 II 216 8 -C 25 R 224 8 -C 26 G 232 8 -C 27 J 240 16 -C OR 27 J 352 32 J > 32743 -C---------------------------------------------- -C -C 1.0 INITIALIZATION - NO. OF ENTRIES IN INDCATOR PARM. -C - NO. OF ENTRIES IN TYPE LEVEL -C - NO. OF ENTRIES IN CNTR PROD. DTA. -C - INITIAL ZEROS IN O.N. 84 LABEL -C - IQ = 255 - IC = 4 - IN = 34 -C -C TEST FOR 32 OR 64 BIT COMPUTER (CRAY) -C - CALL W3FI01(LW) - IF (LW.EQ.4) THEN - NWORDS = 12 - ELSE - NWORDS = 6 - END IF -C -C ZERO OUTPUT ARRAY -C - DO N = 1,NWORDS - ID8(N) = 0 - END DO -C -C --------------------------------------------------------------------- -C 2.0 VERIFY GRIB IN SECTION 0 -C - IF (.NOT. GRIB(1:4) .EQ. IGRIB(1:4)) THEN - IERR = 1 - RETURN - END IF -C -C 2.1 VERIFY THE NO. OF OCTETS IN THE PDS -C - IF (ID(1).NE.28) THEN - IERR = 2 - PRINT *,'IERR = ',IERR,',LENGTH OF PDS = ',ID(1) - RETURN - END IF -C -C 3.0 GENERATING MODEL, TYPE GRID, AND NO. OF GRID PTS. -C -C IF CENTER NOT U.S., STORE CENTER IN G MARKER -C IF CENTER U.S. STORE MODEL NO. IN G MARKER -C - IF (ID(3) .NE. 7) THEN - CALL SBYTE(ID8,ID(3),232,8) - ELSE - CALL SBYTE(ID8,ID(4),232,8) - END IF -C - DO KK = 1,IN - IF (ID(5) .EQ. NGRD(KK)) THEN - IGRDPT = NPTS(KK) - IF (ID(5) .EQ. 6) ID(5) = 26 - CALL SBYTE(ID8,ID(5),152,8) - IF (IGRDPT.LE.32743) THEN - CALL SBYTE(ID8,IGRDPT,240,16) - ELSE - CALL SBYTE(ID8,IGRDPT,352,32) - END IF - GO TO 350 - END IF - END DO - IERR = 4 - PRINT *,'IERR = ',IERR,',GRID TYPE = ',ID(5) - RETURN -C - 350 CONTINUE -C -C COMPUTE R MARKER FROM MODEL NUMBERS FOR U.S. CENTER -C -C (ERL) run - IF (ID(3).EQ.7) THEN - IF (ID(4).EQ.19.OR.ID(4).EQ.53.OR.ID(4).EQ.83.OR. - & ID(4).EQ.84.OR.ID(4).EQ.85) THEN - CALL SBYTE(ID8,0,224,8) -C (NMC) run - ELSE IF (ID(4).EQ.25) THEN - CALL SBYTE(ID8,1,224,8) -C (RGL) run - ELSE IF (ID(4).EQ.39.OR.ID(4).EQ.64) THEN - CALL SBYTE(ID8,2,224,8) -C (AVN) run - ELSE IF (ID(4).EQ.10.OR.ID(4).EQ.42.OR. - & ID(4).EQ.68.OR.ID(4).EQ.73.OR. - & ID(4).EQ.74.OR.ID(4).EQ.75.OR. - & ID(4).EQ.77.OR.ID(4).EQ.81.OR. - & ID(4).EQ.88) THEN - CALL SBYTE(ID8,3,224,8) -C (MRF) run - ELSE IF (ID(4).EQ.69.OR.ID(4).EQ.76.OR. - & ID(4).EQ.78.OR.ID(4).EQ.79.OR. - & ID(4).EQ.80.oR.ID(4).EQ.87) THEN - CALL SBYTE(ID8,4,224,8) -C (FNL) run - ELSE IF (ID(4).EQ.43.OR.ID(4).EQ.44.OR. - & ID(4).EQ.82) THEN - CALL SBYTE(ID8,5,224,8) -C (HCN) run - ELSE IF ( ID(4).EQ.70) THEN - CALL SBYTE(ID8,6,224,8) -C (RUC) run - ELSE IF ( ID(4).EQ.86) THEN - CALL SBYTE(ID8,7,224,8) -C Not applicable, set to 255 - ELSE - CALL SBYTE(ID8,255,224,8) - END IF - END IF -C -C 4.0 FORM TYPE DATA PARAMETER -C - DO II = 1,IQ - III = II - IF (ID(8) .EQ. HH(II)) THEN - IF (LL(II).NE.255) GO TO 410 - PRINT *,'PDS PARAMETER HAS NO OFFICE NOTE 84 Q TYPE' - PRINT *,'PDS BYTE 9 PARAMETER = ',ID(8) - IERR = 3 - RETURN - END IF - END DO - IERR = 3 - PRINT *,'PDS BYTE 9, PARAMETER = ',ID(8) - RETURN -C - 410 CONTINUE -C -C Q DATA TYPE, BITS 1-12 -C - CALL SBYTE(ID8,LL(III),0,12) -C -C TEST FOR 32 OR 64 BIT COMPUTER (CRAY) -C - IF (LW.EQ.4) THEN - IF (ID(8) .EQ. 211) ID8(5) = IOR (ID8(5),MSK4) - IF (ID(8) .EQ. 210) ID8(5) = IOR (ID8(5),MSK4) - ELSE - IF (ID(8) .EQ. 211) ID8(3) = IOR (ID8(3),ISHFT(MSK4,32)) - IF (ID(8) .EQ. 210) ID8(3) = IOR (ID8(3),ISHFT(MSK4,32)) - END IF -C -C 5.0 FORM TYPE LEVEL -C - IF (ID(9) .EQ. 100) THEN - M = 0 - S1 = 8 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - LEVEL = ID(11) - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - END IF - C1 = LEVEL * 10 ** E1 - CALL SBYTE(ID8,C1,36,20) - E1 = IOR(E1,MSK2) - CALL SBYTE(ID8,E1,56,8) -C - ELSE IF (ID(9) .EQ. 103) THEN - M = 0 - S1 = 1 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - LEVEL = ID(11) - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - END IF - C1 = LEVEL * 10 ** E1 - CALL SBYTE(ID8,C1,36,20) - E1 = IOR(E1,MSK2) - CALL SBYTE(ID8,E1,56,8) -C - ELSE IF (ID(9) .EQ. 105) THEN - M = 0 - S1 = 6 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - LEVEL = ID(11) - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - END IF - C1 = LEVEL * 10 ** E1 - CALL SBYTE(ID8,C1,36,20) - E1 = IOR(E1,MSK2) - CALL SBYTE(ID8,E1,56,8) -C - ELSE IF (ID(9) .EQ. 111) THEN - M = 0 - S1 = 7 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - LEVEL = ID(11) - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - END IF - C1 = LEVEL * 10 ** E1 - CALL SBYTE(ID8,C1,36,20) -C XXXXXXX SCALE FROM CENTIMETERS TO METERS. XXXXXXXXXX - E1 = IOR(E1,MSK2) - E1 = E1 + 2 - IF (C1 .EQ. 0) THEN - E1 = 0 - END IF - CALL SBYTE(ID8,E1,56,8) -C - ELSE IF (ID(9) .EQ. 107) THEN - M = 0 - S1 = 148 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - LEVEL = ID(11) - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - ELSE - E1 = 0 - END IF - C1 = LEVEL * 10 ** E1 - DO ISI = 1,7 - IF (C1 .EQ. ICXGB1(ISI)) THEN - C1 = ICXG1(ISI) - END IF - END DO - CALL SBYTE(ID8,C1,36,20) -C***********SCALING OF .0001 TAKEN INTO ACCOUNT - E1 = E1 + 4 - E1 = IOR(E1,MSK2) - IF (C1 .EQ. 0) THEN - E1 = 0 - END IF - CALL SBYTE(ID8,E1,56,8) -C - ELSE IF (ID(9) .EQ. 4) THEN - M = 0 - S1 = 16 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) -C LEVEL = ID(11) -C******* CONSTANT VALUE OF 273.16 WILL HAVE TO BE INSERTED -C LEVEL = IAND (IPDS(3),MSK1) -C IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN -C E1 = 4 -C ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN -C E1 = 3 -C ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN -C E1 = 2 -C ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN -C E1 = 1 -C END IF - E1 = 2 - C1 = (273.16 * 10 ** E1) + .5 - CALL SBYTE(ID8,C1,36,20) - E1 = IOR(E1,MSK2) - CALL SBYTE(ID8,E1,56,8) -C*************SPECIAL CASES ********************* - ELSE IF (ID(9) .EQ. 102) THEN - M = 0 - S1 = 128 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,0,64,32) -C - ELSE IF (ID(9) .EQ. 1) THEN - M = 0 - S1 = 129 -C***** S1 = 133 ALSO POSSIBILITY - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,0,64,32) -C - ELSE IF (ID(9) .EQ. 7) THEN - M = 0 - S1 = 130 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,0,64,32) -C - ELSE IF (ID(9) .EQ. 6) THEN - M = 0 - S1 = 131 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,0,64,32) -C - ELSE IF (ID(9) .EQ. 101) THEN - M = 2 - S1 = 8 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - CALL SBYTE(ID8,S1,76,12) - LEVEL = ID(10) - LEVEL = (LEVEL * .1) * 10 ** 2 - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - END IF - C1 = LEVEL * 10 ** E1 - CALL SBYTE(ID8,C1,36,20) - E1 = IOR(E1,MSK2) - CALL SBYTE(ID8,E1,56,8) - LEVEL2 = ID(11) - LEVEL2 = (LEVEL2 * .1) * 10 ** 2 - IF (LEVEL2 .GE. 1 .AND. LEVEL2 .LE. 9) THEN - E2 = 4 - ELSE IF (LEVEL2 .GE. 10 .AND. LEVEL2 .LE. 99) THEN - E2 = 3 - ELSE IF (LEVEL2 .GE. 100 .AND. LEVEL2 .LE. 999) THEN - E2 = 2 - ELSE IF (LEVEL2 .GE. 1000 .AND. LEVEL2 .LE. 9999) THEN - E2 = 1 - END IF - C2 = LEVEL2 * 10 ** E2 - CALL SBYTE(ID8,C2,100,20) - IF (C2 .EQ. 0) E2 = 0 - E2 = IOR(E2,MSK2) - CALL SBYTE(ID8,E2,120,8) -C - ELSE IF (ID(9) .EQ. 104) THEN - M = 2 - S1 = 1 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - CALL SBYTE(ID8,S1,76,12) - LEVEL = ID(10) - LEVEL = (LEVEL * .1) * 10 ** 2 - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - END IF - C1 = LEVEL * 10 ** E1 - CALL SBYTE(ID8,C1,36,20) - E1 = IOR(E1,MSK2) - CALL SBYTE(ID8,E1,56,8) - LEVEL2 = ID(11) - LEVEL2 = (LEVEL2 * .1) * 10 ** 2 - IF (LEVEL2 .GE. 1 .AND. LEVEL2 .LE. 9) THEN - E2 = 4 - ELSE IF (LEVEL2 .GE. 10 .AND. LEVEL2 .LE. 99) THEN - E2 = 3 - ELSE IF (LEVEL2 .GE. 100 .AND. LEVEL2 .LE. 999) THEN - E2 = 2 - ELSE IF (LEVEL2 .GE. 1000 .AND. LEVEL2 .LE. 9999) THEN - E2 = 1 - END IF - C2 = LEVEL2 * 10 ** E2 - CALL SBYTE(ID8,C2,100,20) - E2 = IOR(E2,MSK2) - CALL SBYTE(ID8,E2,120,8) -C - ELSE IF (ID(9) .EQ. 106) THEN - M = 2 - S1 = 6 - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - CALL SBYTE(ID8,S1,76,12) - LEVEL = ID(10) - LEVEL = (LEVEL * .1) * 10**2 - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - END IF - C1 = LEVEL * 10 ** E1 - CALL SBYTE(ID8,C1,36,20) - E1 = IOR(E1,MSK2) - CALL SBYTE(ID8,E1,56,8) - LEVEL2 = ID(10) - LEVEL2 = (LEVEL2 * .1) * 10 ** 2 - IF (LEVEL2 .GE. 1 .AND. LEVEL2 .LE. 9) THEN - E2 = 4 - ELSE IF (LEVEL2 .GE. 10 .AND. LEVEL2 .LE. 99) THEN - E2 = 3 - ELSE IF (LEVEL2 .GE. 100 .AND. LEVEL2 .LE. 999) THEN - E2 = 2 - ELSE IF (LEVEL2 .GE. 1000 .AND. LEVEL2 .LE. 9999) THEN - E2 = 1 - END IF - C2 = LEVEL2 * 10 ** E2 - CALL SBYTE(ID8,C2,100,20) - E2 = IOR(E2,MSK2) - CALL SBYTE(ID8,E2,120,8) -C - ELSE IF (ID(9) .EQ. 108) THEN - M = 2 - S1 = 148 -C**** S1 = 144 ALSO POSSIBILITY -C**** S1 = 145 ALSO POSSIBILITY - CALL SBYTE(ID8,S1,12,12) - CALL SBYTE(ID8,M,64,4) - CALL SBYTE(ID8,S1,76,12) - LEVEL = ID(10) - LEVEL = LEVEL - IF (LEVEL .GE. 1 .AND. LEVEL .LE. 9) THEN - E1 = 4 - ELSE IF (LEVEL .GE. 10 .AND. LEVEL .LE. 99) THEN - E1 = 3 - ELSE IF (LEVEL .GE. 100 .AND. LEVEL .LE. 999) THEN - E1 = 2 - ELSE IF (LEVEL .GE. 1000 .AND. LEVEL .LE. 9999) THEN - E1 = 1 - END IF - C1 = LEVEL * (10 ** E1) - DO ISI = 1,9 - IF (C1 .EQ. ICXGB2(ISI)) THEN - C1 = ICXG2(ISI) - END IF - END DO - CALL SBYTE(ID8,C1,36,20) - IF (C1 .EQ. 0) THEN - E1 = 0 - CALL SBYTE(ID8,E1,56,8) - GO TO 700 - END IF -C*****TAKE SCALING INTO ACCOUNT .01 - E1 = E1 + 2 - E1 = IOR(E1,MSK2) - CALL SBYTE(ID8,E1,56,8) -C - 700 CONTINUE - LEVEL2 = ID(11) - LEVEL2 = LEVEL2 - IF (LEVEL2 .GE. 1 .AND. LEVEL2 .LE. 9) THEN - E2 = 4 - ELSE IF (LEVEL2 .GE. 10 .AND. LEVEL2 .LE. 99) THEN - E2 = 3 - ELSE IF (LEVEL2 .GE. 100 .AND. LEVEL2 .LE. 999) THEN - E2 = 2 - ELSE IF (LEVEL2 .GE. 1000 .AND. LEVEL2 .LE. 9999) THEN - E2 = 1 - END IF - C2 = LEVEL2 * 10 ** E2 - DO ISI = 1,9 - IF (C2 .EQ. ICXGB2(ISI)) THEN - C2 = ICXG2(ISI) - END IF - END DO - CALL SBYTE(ID8,C2,100,20) - E2 = IOR(E2,MSK2) - CALL SBYTE(ID8,E2,120,8) -C*******TAKE SCALING INTO ACCOUNT .01 - E2 = E2 + 2 - E2 = IOR(E2,MSK2) - CALL SBYTE(ID8,E2,120,8) -C - END IF -C 5.1 FORCAST TIMES ,PLUS THE T MARKER AND CM FIELD -C - TR = ID(20) - IF (TR .EQ. 0) THEN - P1 = ID(18) - CALL SBYTE(ID8,ID(18),24,8) - ELSE IF (TR .EQ. 4) THEN - P2 = ID(19) - CALL SBYTE(ID8,P2,24,8) - P1 = ID(18) - CALL SBYTE(ID8,(P2 - P1),88,8) - T = 3 - CALL SBYTE(ID8,T,32,4) - ELSE IF (TR .EQ. 5) THEN - P2 = ID(19) - CALL SBYTE(ID8,P2,24,8) - P1 = ID(18) - CALL SBYTE(ID8,(P2 - P1),88,8) - T = 3 - CALL SBYTE(ID8,T,32,4) -C - ELSE IF (TR .EQ. 124) THEN - FTU = ID(17) - IF (FTU .EQ. 2) THEN - F1 = ID(21) - CALL SBYTE(ID8,F1,24,8) - T = 4 - CALL SBYTE(ID8,T,32,4) - ELSE IF (FTU .EQ. 4) THEN - F2 = ID(21) - CALL SBYTE(ID8,F2,88,8) - T = 4 - CALL SBYTE(ID8,T,32,4) - END IF -C - ELSE IF (TR .EQ.123) THEN - F1 = 3 - F1 = IOR(F1,MSK2) - CALL SBYTE(ID8,F1,24,8) - F2 = 5 * 2 - CALL SBYTE(ID8,F2,88,8) - T = 6 - CALL SBYTE(ID8,T,32,4) - RINC = 0.0 - RINC(2) = 36.0 - IYR=MOVA2I(PDS(13)) - PRINT *, 'IYR = ', IYR - IF(IYR.LT.20)THEN - MDATE(1)=2000+IYR - ELSE - MDATE(1)=1900+IYR - ENDIF - MDATE(2) = MOVA2I(PDS(14)) - MDATE(3) = MOVA2I(PDS(15)) - MDATE(5) = MOVA2I(PDS(16)) -C PRINT *, 'OLD DATE = ', MDATE(1), MDATE(2), MDATE(3), MDATE(5) -C PRINT *, 'CHANGE DATE BY - ', RINC(2) - CALL W3MOVDAT(RINC,MDATE,NDATE) -C PRINT *, 'NEW DATE = ', NDATE(1), NDATE(2), NDATE(3), NDATE(5) -C CALL W3FS04 (IDATE,JDATE,3,IERR) - IYEAR = MOD(NDATE(1),100) - JWORK(1) = CHAR(IYEAR) - JWORK(2) = CHAR(NDATE(2)) - JWORK(3) = CHAR(NDATE(3)) - JWORK(4) = CHAR(NDATE(5)) - IDATE = JDATE - GO TO 710 -C - ELSE IF (TR .EQ.3) THEN - P1 = ID(18) - P2 = ID(19) - F1 = P1 / 12 - CALL SBYTE(ID8,F1,24,8) -C -C ***** NAVG IS IN BITES 22 23 ***** -C USING BITE 23 ONLY ******* -C FIX LATER ****************************************** -C -C NAVG = MOVA2I(PDS(23)) - F2 = (P2 - P1) / 12 - CALL SBYTE(ID8,F2,88,8) - T = 6 - CALL SBYTE(ID8,T,32,4) - RINC = 0.0 - RINC(2) = -36.0 - IYR=MOVA2I(PDS(13)) - PRINT *, 'IYR = ', IYR - IF(IYR.LT.20)THEN - MDATE(1)=2000+IYR - ELSE - MDATE(1)=1900+IYR - ENDIF - MDATE(2) = MOVA2I(PDS(14)) - MDATE(3) = MOVA2I(PDS(15)) - MDATE(5) = MOVA2I(PDS(16)) -C PRINT *, 'OLD DATE = ', MDATE(1), MDATE(2), MDATE(3), MDATE(5) -C PRINT *, 'CHANGE DATE BY - ', RINC(2) - CALL W3MOVDAT(RINC,MDATE,NDATE) -C PRINT *, 'NEW DATE = ', NDATE(1), NDATE(2), NDATE(3), NDATE(5) -C CALL W3FS04 (IDATE,JDATE,-3,IERR) - IYEAR = MOD(NDATE(1),100) - JWORK(1) = CHAR(IYEAR) - JWORK(2) = CHAR(NDATE(2)) - JWORK(3) = CHAR(NDATE(3)) - JWORK(4) = CHAR(NDATE(5)) - IDATE = JDATE - GO TO 710 - END IF -C -C 7.0 TRANSFER THE DATE -C - IWORK(1) = PDS(13) - IWORK(2) = PDS(14) - IWORK(3) = PDS(15) - IWORK(4) = PDS(16) -C - 710 CONTINUE -C -C TEST FOR 64 BIT COMPUTER (CRAY) -C - IF (LW.EQ.8) IDATE = ISHFT(IDATE,-32) - CALL SBYTE(ID8,IDATE,192,32) -C - IERR = 0 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fs13.f b/external/w3nco/v2.0.6/src/w3fs13.f deleted file mode 100644 index 8d1fd0ef0..000000000 --- a/external/w3nco/v2.0.6/src/w3fs13.f +++ /dev/null @@ -1,52 +0,0 @@ - SUBROUTINE W3FS13(IYR,IMO,IDA,JDY) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: W3FS13 YEAR, MONTH, AND DAY TO DAY OF YEAR -C AUTHOR: CHASE, P. ORG: W345 DATE: 85-07-31 -C -C ABSTRACT: CONVERTS YEAR, MONTH AND DAY TO DAY OF YEAR. -C -C PROGRAM HISTORY LOG: -C 85-07-31 R.E.JONES -C 89-11-02 R.E.JONES CONVERT TO CRAY CFT77 FORTRAN -C -C USAGE: CALL W3FS13(IYR, IMO, IDA, JDY) -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C IYR ARG LIST INTEGER YEAR OF CENTURY, 00-99 OR YEAR OF ERA, -C 1901-2099 -C IMO ARG LIST INTEGER MONTH OF YEAR, 1-12 -C IDA ARG LIST INTEGER DAY OF MONTH, 1-31 -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C JDY ARG LIST INTEGER DAY OF YEAR, 1-366 -C -C SUBPROGRAMS CALLED: -C NAMES LIBRARY -C ------------------------------------------------------- -------- -C IAND SYSTEM -C -C REMARKS: THIS PROCEDURE IS VALID ONLY FROM THE YEARS 1901-2099 -C INCLUSIVE. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C - INTEGER JTABLE(24) -C - DATA JTABLE/0,0,31,31,60,59,91,90,121,120,152,151, - & 182,181,213,212,244,243,274,273,305,304,335,334/ -C - ISET = 0 - IF (IAND(IYR,3).EQ.0) ISET = 1 - I = IMO * 2 - ISET - JDY = JTABLE(I) + IDA - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fs15.f b/external/w3nco/v2.0.6/src/w3fs15.f deleted file mode 100644 index a6ad15294..000000000 --- a/external/w3nco/v2.0.6/src/w3fs15.f +++ /dev/null @@ -1,212 +0,0 @@ - SUBROUTINE W3FS15(IDATE,JTAU,NDATE) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FS15 UPDATING OFFICE NOTE 85 DATE/TIME WORD -C PRGMMR: REJONES ORG: NMC421 DATE: 89-08-23 -C -C ABSTRACT: UPDATES OR BACKDATES A FULLWORD DATE/TIME WORD (O.N. 84) -C BY A SPECIFIED NUMBER OF HOURS. -C -C PROGRAM HISTORY LOG: -C ??-??-?? R.ALLARD -C 87-02-19 R.E.JONES CLEAN UP CODE -C 87-02-19 R.E.JONES CHANGE TO MICROSOFT FORTRAN 4.10 -C 89-05-12 R.E.JONES CORRECT ORDER OF BYTES IN DATE WORD FOR PC -C 89-08-04 R.E.JONES CLEAN UP CODE, GET RID OF ASSIGN, CORRECTION -C FOR MEMORY SET TO INDEFINITE. -C 89-10-25 R.E.JONES CHANGE TO CRAY CFT77 FORTRAN -C 95-11-15 R.E.JONES ADD SAVE STATEMENT -C 02-10-15 VUONG REPLACED FUNCTION ICHAR WITH MOVA2I -C -C USAGE: CALL W3FS15 (IDATE, JTAU, NDATE) -C INPUT ARGUMENT LIST: -C IDATE - PACKED BINARY DATE/TIME AS FOLLOWS: -C BYTE 1 IS YEAR OF CENTURY 00-99 -C BYTE 2 IS MONTH 01-12 -C BYTE 3 IS DAY OF MONTH 01-31 -C BYTE 4 IS HOUR 00-23 -C SUBROUTINE TAKES ADVANTAGE OF FORTRAN ADDRESS -C PASSING, IDATE AND NDATE MAY BE -C A CHARACTER*1 ARRAY OF FOUR, THE LEFT 32 -C BITS OF 64 BIT INTEGER WORD. AN OFFICE NOTE 85 -C LABEL CAN BE STORED IN -C 4 INTEGER WORDS. -C IF INTEGER THE 2ND WORD IS USED. OUTPUT -C IS STORED IN LEFT 32 BITS. FOR A OFFICE NOTE 84 -C LABEL THE 7TH WORD IS IN THE 4TH CRAY 64 BIT -C INTEGER, THE LEFT 32 BITS. -C JTAU - INTEGER NUMBER OF HOURS TO UPDATE (IF POSITIVE) -C OR BACKDATE (IF NEGATIVE) -C -C OUTPUT ARGUMENT LIST: -C NDATE - NEW DATE/TIME WORD RETURNED IN THE -C SAME FORMAT AS 'IDATE'. 'NDATE' AND 'IDATE' MAY -C BE THE SAME VARIABLE. -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - NONE -C -C RESTRICTIONS: THIS ROUTINE IS VALID ONLY FOR THE 20TH CENTURY. -C -C NOTES: THE FORMAT OF THE DATE/TIME WORD IS THE SAME AS THE -C SEVENTH WORD OF THE PACKED DATA FIELD LABEL (SEE O.N. 84) AND -C THE THIRD WORD OF A BINARY DATA SET LABEL (SEE O.N. 85). -C -C EXIT STATES: -C AN ERROR FOUND BY OUT OF RANGE TESTS ON THE GIVEN DATE/TIME -C INFORMATION WILL BE INDICATED BY RETURNING A BINARY ZERO WORD -C IN 'NDATE'. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C - INTEGER ITABYR(13) - INTEGER LPTB(13) - INTEGER NOLPTB(13) -C - CHARACTER*1 IDATE(4) - CHARACTER*1 NDATE(4) -C - SAVE -C - DATA LPTB /0000,0744,1440,2184,2904,3648,4368,5112, - & 5856,6576,7320,8040,8784/ - DATA NOLPTB/0000,0744,1416,2160,2880,3624,4344,5088, - & 5832,6552,7296,8016,8760/ - DATA ICENTY/1900/ -C -C ...WHERE ICENTY IS FOR THE 20TH CENTURY ASSUMED FOR THE GIVEN -C ... YEAR WITHIN THE CENTURY -C - IYR = MOVA2I(IDATE(1)) - IMONTH = MOVA2I(IDATE(2)) - IDAY = MOVA2I(IDATE(3)) - IHOUR = MOVA2I(IDATE(4)) -C - IF (IYR .GT. 99) GO TO 1600 - IF (IMONTH .LE. 0) GO TO 1600 - IF (IMONTH .GT. 12) GO TO 1600 - IF (IDAY .LE. 0) GO TO 1600 - IF (IDAY .GT. 31) GO TO 1600 - IF (IHOUR .LT. 0) GO TO 1600 - IF (IHOUR .GT. 24) GO TO 1600 - IF (JTAU .NE. 0) GO TO 100 -C - NDATE(1) = IDATE(1) - NDATE(2) = IDATE(2) - NDATE(3) = IDATE(3) - NDATE(4) = IDATE(4) - RETURN -C - 100 CONTINUE - JAHR = IYR + ICENTY - KABUL = 1 - GO TO 900 -C -C ...WHERE 900 IS SUBROUTINE TO INITIALIZE ITABYR -C ...AND RETURN THRU KABUL -C - 200 CONTINUE - IHRYR = IHOUR + 24 * (IDAY - 1) + ITABYR(IMONTH) - IHRYR2 = IHRYR + JTAU -C -C ...TO TEST FOR BACKDATED INTO PREVIOUS YEAR... -C - 300 CONTINUE - IF (IHRYR2 .LT. 0) GO TO 700 -C - DO 400 M = 2,13 - IF (IHRYR2 .LT. ITABYR(M)) GO TO 600 - 400 CONTINUE -C -C ...IF IT FALLS THRU LOOP TO HERE, IT IS INTO NEXT YEAR... -C - JAHR = JAHR + 1 - IHRYR2 = IHRYR2 - ITABYR(13) - KABUL = 2 - GO TO 900 -C - 600 CONTINUE - MONAT = M - 1 - IHRMO = IHRYR2 - ITABYR(MONAT) - NODAYS = IHRMO / 24 - ITAG = NODAYS + 1 - IUHR = IHRMO - NODAYS * 24 - GO TO 1500 -C -C ...ALL FINISHED. RETURN TO CALLING PROGRAM....................... -C ...COMES TO 700 IF NEG TOTAL HRS. BACK UP INTO PREVIOUS YEAR -C - 700 CONTINUE - JAHR = JAHR - 1 - KABUL = 3 - GO TO 900 -C -C ...WHICH IS CALL TO INITIALIZE ITABYR AND RETURN THRU KABUL -C - 800 CONTINUE - IHRYR2 = ITABYR(13) + IHRYR2 - GO TO 300 -C -C ...SUBROUTINE INITYR... -C ...CALLED BY GO TO 900 AFTER ASSIGNING RETURN NO. TO KABUL... -C ...ITABYR HAS MONTHLY ACCUMULATING TOTAL HRS REL TO BEGIN OF YR. -C ...DEPENDS ON WHETHER JAHR IS LEAP YEAR OR NOT. -C - 900 CONTINUE - IQUOT = JAHR / 4 - IRMNDR = JAHR - 4 * IQUOT - IF (IRMNDR .NE. 0) GO TO 1000 -C -C ...WAS MODULO 4, SO MOST LIKELY A LEAP YEAR, -C - IQUOT = JAHR / 100 - IRMNDR = JAHR - 100 * IQUOT - IF (IRMNDR .NE. 0) GO TO 1200 -C -C ...COMES THIS WAY IF A CENTURY YEAR... -C - IQUOT = JAHR / 400 - IRMNDR = JAHR - 400 * IQUOT - IF (IRMNDR .EQ. 0) GO TO 1200 -C -C ...COMES TO 1000 IF NOT A LEAP YEAR... -C - 1000 CONTINUE - DO 1100 I = 1,13 - ITABYR(I) = NOLPTB(I) - 1100 CONTINUE - GO TO 1400 -C -C ...COMES TO 1200 IF LEAP YEAR -C - 1200 CONTINUE - DO 1300 I = 1,13 - ITABYR(I) = LPTB(I) - 1300 CONTINUE -C - 1400 CONTINUE - GO TO (200,300,800) KABUL -C - 1500 CONTINUE - JAHR = MOD(JAHR,100) - NDATE(1) = CHAR(JAHR) - NDATE(2) = CHAR(MONAT) - NDATE(3) = CHAR(ITAG) - NDATE(4) = CHAR(IUHR) - RETURN -C - 1600 CONTINUE - NDATE(1) = CHAR(0) - NDATE(2) = CHAR(0) - NDATE(3) = CHAR(0) - NDATE(4) = CHAR(0) -C -C ...WHICH FLAGS AN ERROR CONDITION ... -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fs21.f b/external/w3nco/v2.0.6/src/w3fs21.f deleted file mode 100644 index 3593d6ffe..000000000 --- a/external/w3nco/v2.0.6/src/w3fs21.f +++ /dev/null @@ -1,77 +0,0 @@ - SUBROUTINE W3FS21(IDATE, NMIN) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3FS21 NUMBER OF MINUTES SINCE JAN 1, 1978 -C PRGMMR: REJONES ORG: NMC421 DATE: 89-07-17 -C -C ABSTRACT: CALCULATES THE NUMBER OF MINUTES SINCE 0000, -C 1 JANUARY 1978. -C -C PROGRAM HISTORY LOG: -C 84-06-21 A. DESMARAIS -C 89-07-14 R.E.JONES CONVERT TO CYBER 205 FORTRAN 200, -C CHANGE LOGIC SO IT WILL WORK IN -C 21 CENTURY. -C 89-11-02 R.E.JONES CONVERT TO CRAY CFT77 FORTRAN -C -C USAGE: CALL W3FS21 (IDATE, NMIN) -C INPUT ARGUMENT LIST: -C IDATE - INTEGER SIZE 5 ARRAY CONTAINING YEAR OF CENTURY, -C MONTH, DAY, HOUR AND MINUTE. IDATE(1) MAY BE -C A TWO DIGIT YEAR OR 4. IF 2 DIGITS AND GE THAN 78 -C 1900 IS ADDED TO IT. IF LT 78 THEN 2000 IS ADDED -C TO IT. IF 4 DIGITS THE SUBROUTINE WILL WORK -C CORRECTLY TO THE YEAR 3300 A.D. -C -C OUTPUT ARGUMENT LIST: -C NMIN - INTEGER NUMBER OF MINUTES SINCE 1 JANUARY 1978 -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - IW3JDN -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C - INTEGER IDATE(5) - INTEGER NMIN - INTEGER JDN78 -C - DATA JDN78 / 2443510 / -C -C*** IDATE(1) YEAR OF CENTURY -C*** IDATE(2) MONTH OF YEAR -C*** IDATE(3) DAY OF MONTH -C*** IDATE(4) HOUR OF DAY -C*** IDATE(5) MINUTE OF HOUR -C - NMIN = 0 -C - IYEAR = IDATE(1) -C - IF (IYEAR.LE.99) THEN - IF (IYEAR.LT.78) THEN - IYEAR = IYEAR + 2000 - ELSE - IYEAR = IYEAR + 1900 - ENDIF - ENDIF -C -C COMPUTE JULIAN DAY NUMBER FROM YEAR, MONTH, DAY -C - IJDN = IW3JDN(IYEAR,IDATE(2),IDATE(3)) -C -C SUBTRACT JULIAN DAY NUMBER OF JAN 1,1978 TO GET THE -C NUMBER OF DAYS BETWEEN DATES -C - NDAYS = IJDN - JDN78 -C -C*** NUMBER OF MINUTES -C - NMIN = NDAYS * 1440 + IDATE(4) * 60 + IDATE(5) -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3fs26.f b/external/w3nco/v2.0.6/src/w3fs26.f deleted file mode 100644 index bad845d47..000000000 --- a/external/w3nco/v2.0.6/src/w3fs26.f +++ /dev/null @@ -1,87 +0,0 @@ - SUBROUTINE W3FS26(JLDAYN,IYEAR,MONTH,IDAY,IDAYWK,IDAYYR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: W3FS26 YEAR, MONTH, DAY FROM JULIAN DAY NUMBER -C AUTHOR: JONES,R.E. ORG: W342 DATE: 87-03-29 -C -C ABSTRACT: COMPUTES YEAR (4 DIGITS), MONTH, DAY, DAY OF WEEK, DAY -C OF YEAR FROM JULIAN DAY NUMBER. THIS SUBROUTINE WILL WORK -C FROM 1583 A.D. TO 3300 A.D. -C -C PROGRAM HISTORY LOG: -C 87-03-29 R.E.JONES -C 89-10-25 R.E.JONES CONVERT TO CRAY CFT77 FORTRAN -C -C USAGE: CALL W3FS26(JLDAYN,IYEAR,MONTH,IDAY,IDAYWK,IDAYYR) -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C JLDAYN ARG LIST INTEGER JULIAN DAY NUMBER -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C IYEAR ARG LIST INTEGER YEAR (4 DIGITS) -C MONTH ARG LIST INTEGER MONTH -C IDAY ARG LIST INTEGER DAY -C IDAYWK ARG LIST INTEGER DAY OF WEEK (1 IS SUNDAY, 7 IS SAT) -C IDAYYR ARG LIST INTEGER DAY OF YEAR (1 TO 366) -C -C REMARKS: A JULIAN DAY NUMBER CAN BE COMPUTED BY USING ONE OF THE -C FOLLOWING STATEMENT FUNCTIONS. A DAY OF WEEK CAN BE COMPUTED -C FROM THE JULIAN DAY NUMBER. A DAY OF YEAR CAN BE COMPUTED FROM -C A JULIAN DAY NUMBER AND YEAR. -C -C IYEAR (4 DIGITS) -C -C JDN(IYEAR,MONTH,IDAY) = IDAY - 32075 -C & + 1461 * (IYEAR + 4800 + (MONTH - 14) / 12) / 4 -C & + 367 * (MONTH - 2 - (MONTH -14) / 12 * 12) / 12 -C & - 3 * ((IYEAR + 4900 + (MONTH - 14) / 12) / 100) / 4 -C -C IYR (4 DIGITS) , IDYR(1-366) DAY OF YEAR -C -C JULIAN(IYR,IDYR) = -31739 + 1461 * (IYR + 4799) / 4 -C & -3 * ((IYR + 4899) / 100) / 4 + IDYR -C -C DAY OF WEEK FROM JULIAN DAY NUMBER, 1 IS SUNDAY, 7 IS SATURDAY. -C -C JDAYWK(JLDAYN) = MOD((JLDAYN + 1),7) + 1 -C -C DAY OF YEAR FROM JULIAN DAY NUMBER AND 4 DIGIT YEAR. -C -C JDAYYR(JLDAYN,IYEAR) = JLDAYN - -C & (-31739+1461*(IYEAR+4799)/4-3*((IYEAR+4899)/100)/4) -C -C THE FIRST FUNCTION WAS IN A LETTER TO THE EDITOR COMMUNICATIONS -C OF THE ACM VOLUME 11 / NUMBER 10 / OCTOBER, 1968. THE 2ND -C FUNCTION WAS DERIVED FROM THE FIRST. THIS SUBROUTINE WAS ALSO -C INCLUDED IN THE SAME LETTER. JULIAN DAY NUMBER 1 IS -C JAN 1,4713 B.C. A JULIAN DAY NUMBER CAN BE USED TO REPLACE A -C DAY OF CENTURY, THIS WILL TAKE CARE OF THE DATE PROBLEM IN -C THE YEAR 2000, OR REDUCE PROGRAM CHANGES TO ONE LINE CHANGE -C OF 1900 TO 2000. JULIAN DAY NUMBERS CAN BE USED FOR FINDING -C RECORD NUMBERS IN AN ARCHIVE OR DAY OF WEEK, OR DAY OF YEAR. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/864 -C -C$$$ -C - L = JLDAYN + 68569 - N = 4 * L / 146097 - L = L - (146097 * N + 3) / 4 - I = 4000 * (L + 1) / 1461001 - L = L - 1461 * I / 4 + 31 - J = 80 * L / 2447 - IDAY = L - 2447 * J / 80 - L = J / 11 - MONTH = J + 2 - 12 * L - IYEAR = 100 * (N - 49) + I + L - IDAYWK = MOD((JLDAYN + 1),7) + 1 - IDAYYR = JLDAYN - - & (-31739 +1461 * (IYEAR+4799) / 4 - 3 * ((IYEAR+4899)/100)/4) - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3ft32.f b/external/w3nco/v2.0.6/src/w3ft32.f deleted file mode 100644 index 7614b846f..000000000 --- a/external/w3nco/v2.0.6/src/w3ft32.f +++ /dev/null @@ -1,1235 +0,0 @@ - SUBROUTINE W3FT32(FIELD, MAPIN, DATA, MAPOUT, INTERP, IER) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK *** -C -C SUBPROGRAM: W3FT32 GENERAL INTERPOLATOR BETWEEN NMC FLDS -C PRGMMR: KEYSER ORG: NMC22 DATE:93-02-17 -C -C ABSTRACT: INTERPOLATE SCALAR QUANTITY FROM ANY GIVEN NMC -C FIELD (IN OFFICE NOTE 84) TO ANY OTHER FIELD. CAN DO BILINEARLY -C OR BIQUADRATICALLY. WILL NOT ROTATE WIND COMPONENTS. -C INPUT AND OUTPUT FIELDS ARE REAL*4 UNPACKED -C -C PROGRAM HISTORY LOG: -C 74-06-15 JOHN STACKPOLE -C 87-07-15 B. CAVANAUGH ADD GRID TYPE 100, 101 TO TABLES. -C 90-08-08 J. STACKPOLE CORRECT ROTATION ERROR WRT 100, 101 -C 90-08-31 R.E. JONES CHANGE NAME FROM POLATE TO W3FT32 -C 93-01-26 D. A. KEYSER ADDED GRID TYPES 87, 105, 106, 107 TO -C TABLES (AS BOTH INPUT AND OUTPUT). -C -C USAGE: CALL W3FT32(FIELD, MAPIN, DATA, MAPOUT, INTERP, IER) -C INPUT ARGUMENTS: -C FIELD - REAL*4 - TWO DIMENSIONAL ARRAY. -C MAPIN - INTEGER*4 - NMC MAP NUMBER (K) FOR GIVEN INPUT FIELD. -C MAPOUT - INTEGER*4 - NMC MAP NUMBER (K) FOR WANTED OUTPUT FIELD. -C INTERP - INTEGER*4 - SET INTERPOLATION METHOD: -C EQ 1 - LINEAR -C NE 1 - BIQUADRATIC -C INPUT FILES: NONE -C -C OUTPUT ARGUMENTS: -C DATA - REAL*4 - ARRAY TO HOLD OUTPUT MAP (UNPACKED). -C IER - INTEGER*4 - COMPLETION CONDITION FLAG -C -C OUTPUT FILES: NONE -C -C -C RETURN CONDITIONS: -C IER = 0 - NO DIFFICULTIES -C 1 - MAPIN NOT RECOGNIZED -C 2 - MAPOUT NOT RECOGNIZED -C 3 - PARTICULAR POLA MAPOUT NOT RECOGNIZED -C 4 - PARTICULAR LOLA MAPOUT NOT RECOGNIZED -C 5 - PARTICULAR LOLA MAPIN NOT RECOGNIZED -C 6 - PARTICULAR POLA MAPOUT NOT RECOGNIZED -C 7 - PARTICULAR LOLA MAPIN NOT RECOGNIZED -C 8 - PARTICULAR LOLA MAPOUT NOT RECOGNIZED -C THESE FLAGS ARE SET AT VARIOUS TEST LOCATIONS -C PLEASE REFER TO THE CODE LISTING FOR DETAILS -C -C SUBPROGRAMS CALLED: -C UNIQUE : NONE -C -C LIBRARY: W3FB01, W3FB02, W3FB03, W3FB04, W3FT00, W3FT01 -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/864 -C -C INFORMATION: SEE COMMENT CARDS FOLLOWING FOR MORE DETAIL -C INCLUDING RECIPES FOR ADDING MORE INPUT AND -C OUTPUT MAPS AS THE NEED ARISES. -C$$$ -C -C INTERPOLATE INFORMATION FROM FIELD (MAP TYPE K = MAPIN) -C TO DATA (MAP TYPE K = MAPOUT) -C INTERP SETS INTERPOLATION METHOD -C = 1 BILINEAR, OTHERWISE BIQUADRATIC -C - REAL DATA(*), FIELD(*) -C -C RESTRICTION AND RULES: -C -C AT PRESENT W3FT32 WILL ACCEPT ONLY THE FOLLOWING TYPES -C POLAR STEREOGRAPHIC -C K = 5 & 26 (LFM ANL & FCST RESPECTIVELY) -C 27 & 28 (65X65) -C 25 (53X57 SOUTHERN HEMISPHERE) -C 49 (129X129 NH; 190.5 KM) -C 50 (129X129 SH; 190.5 KM) -C 55 (87X71 NH; LFM ORIENT; 254 KM) -C 56 (87X71 NA; LFM ORIENT; 174 KM) -C 60 (57X57 ENLARGED LFM 'VLFM') -C 87 (81X62 MAPS ANAL/FCST GRID; 68.153 KM) -C 100 (83X83 NGM C-GRID; 91.452) -C 101 (113X91 NGM BIG C-GRID; 91.452) -C 105 (83X83 NGM SUPER C-GRID SUBSET; 90.75464 KM) -C 106 (165X117 HI RESOLUTION GRID; 45.37732 KM) -C 107 (120X92 HI RESOLUTION GRID SUBSET; 45.37732 KM) -C -C LONGITUDE/LATITUDE: ('LOLA') -C K = 29 & 30 (145X37) -C 33 & 34 (181X46) -C 45 & 46 (97X25 - 3.75 DEG LOLA) -C 21 & 22 (73X19 - 5 DEG LOLA) -C 21 & 22 (73X19 - 5 DEG LOLA) -C -C WILL OUTPUT: -C POLAR STEREO: -C K = 5 (53X57) LFM -C 25 (53X57 SOUTH HEMISPHERE) -C 26 (53X45) LFM -C 27 & 28 (65X65) -C 49 (129X129 NH POLA) (1/2 BEDIENT MESH;ORIENTED 80W) -C 50 (129X129 SH POLA) (1/2 BEDIENT MESH;ORINETED 80W) -C 51 (129X129 NH POLA) (SAME MESHL; ORIENTED AT 105W) -C 55 (NH 87X71 254 KM, LFM ORIENT) -C 56 (NA 87X71 127 KM, LFM ORIENT) -C 60 (57X57 ENLARGED LFM 'VLFM') -C 87 (81X62 MAPS ANAL/FCST GRID; 68.153 KM) -C 100 (83X83 NGM C-GRID) -C 101 (113X91 NGM BIG C-GRID) -C 105 (83X83 NGM SUPER C-GRID SUBSET; 90.75464 KM) -C 106 (165X117 HI RESOLUTION GRID; 45.37732 KM) -C 107 (120X92 HI RESOLUTION GRID SUBSET; 45.37732 KM) -C 400 (39X39 1:40MIL 80 DEG VERTICAL POLA) -C 401 (25X35 1:20MIL U.S. SECTION ROTATED) -C 402 (97X97 1-20MIL N.H. POLA ROTATED TO 105W VERT) -C 403 (97X97 1-20MIL S.H. POLA UNROTATED 80W TOP VERT) -C LOLA: -C K = 29 & 30 (145X37) -C 33 & 34 (181X46) -C 45 & 46 (97X25 - 3.75 DEG LOLA) -C 500 & 501 US SECTIONAL NEP 36 & 45 -C -C FEEL FREE, GENTLE READER, TO AUGMENT THE LIST AS YOU WISH -C AND HERE IS A RECIPE FOR ADDING A NEW OUTPUT GRID -C (POLA IN THIS CASE, BUT I AM SURE YOU CAN DRAW THE ANALOGY) -C STEP1 -C PUT NEW NUMBER IN COMMENT ABOVE -C STEP 2 -C ADD IT TO MAPOUT LIST NEAR STMT 30 -C STEP 3 -C ADD SET OF PARAMETERS AT STMT 2000 (FOR POLA) -C STEP4 -C ADD SET OF PARAMETERS AT STMT 6000 (FOR POLA) -C -C HERE TOO IS A RECIPE FOR ADDING A NEW (POLA) INPUT GRID -C -C STEP 1: -C PUT NEW NUMBER IN COMMENT ABOVE -C STEP2: -C ADD NUMBER TO IF(MAPIN.. ) TEST BELOW -C STEP 3: -C ADD INPUT MAP CHARACTERISTICS AT STMT 1000 -C STEP 4: -C DITTO AT STMT 3000 -C - LOGICAL LOLAIN, POLAIN, LOLAOU, POLAOU -C - SAVE -C -C BEGIN HERE - SET ERROR RETURN TO O.K. -C - IER = 0 -C -C DETERMINE WHETHER INPUT GRID IS LOLA OR POLA -C -C THIS LIST CAN BE AUGMENTED ONLY AT THE COST OF A LOT OF -C WORK ELSEWHERE IN THE PROGRAM -C HAVE AT IT IF YOU WANT OTHER MAPS -C -C POLA MAPS -C - IF (MAPIN.EQ. 5) GO TO 10 - IF (MAPIN.EQ.25) GO TO 10 - IF (MAPIN.EQ.26) GO TO 10 - IF (MAPIN.EQ.27) GO TO 10 - IF (MAPIN.EQ.28) GO TO 10 - IF (MAPIN.EQ.49) GO TO 10 - IF (MAPIN.EQ.50) GO TO 10 - IF (MAPIN.EQ.51) GO TO 10 - IF (MAPIN.EQ.55) GO TO 10 - IF (MAPIN.EQ.56) GO TO 10 - IF (MAPIN.EQ.60) GO TO 10 - IF (MAPIN.EQ.87) GO TO 10 - IF (MAPIN.EQ.100) GO TO 10 - IF (MAPIN.EQ.101) GO TO 10 - IF (MAPIN.EQ.105) GO TO 10 - IF (MAPIN.EQ.106) GO TO 10 - IF (MAPIN.EQ.107) GO TO 10 -C -C LOLA MAPS -C - IF (MAPIN.EQ.21) GO TO 20 - IF (MAPIN.EQ.22) GO TO 20 - IF (MAPIN.EQ.29) GO TO 20 - IF (MAPIN.EQ.30) GO TO 20 - IF (MAPIN.EQ.33) GO TO 20 - IF (MAPIN.EQ.34) GO TO 20 - IF (MAPIN.EQ.45) GO TO 20 - IF (MAPIN.EQ.46) GO TO 20 -C -C IF NO MATCH - ERROR -C - IER = 1 - RETURN -C -C SET LOGICAL FLAGS -C - 10 LOLAIN = .FALSE. - POLAIN = .TRUE. - GO TO 30 -C - 20 LOLAIN = .TRUE. - POLAIN = .FALSE. -C -C DITTO FOR OUTPUT MAP TYPE -C -C POLA MAPS -C - 30 IF (MAPOUT.EQ. 5) GO TO 40 - IF (MAPOUT.EQ.25) GO TO 40 - IF (MAPOUT.EQ.26) GO TO 40 - IF (MAPOUT.EQ.27) GO TO 40 - IF (MAPOUT.EQ.28) GO TO 40 - IF (MAPOUT.EQ.49) GO TO 40 - IF (MAPOUT.EQ.50) GO TO 40 - IF (MAPOUT.EQ.51) GO TO 40 - IF (MAPOUT.EQ.55) GO TO 40 - IF (MAPOUT.EQ.56) GO TO 40 - IF (MAPOUT.EQ.60) GO TO 40 - IF (MAPOUT.EQ.87) GO TO 40 - IF (MAPOUT.EQ.100) GO TO 40 - IF (MAPOUT.EQ.101) GO TO 40 - IF (MAPOUT.EQ.105) GO TO 40 - IF (MAPOUT.EQ.106) GO TO 40 - IF (MAPOUT.EQ.107) GO TO 40 - IF (MAPOUT.EQ.400) GO TO 40 - IF (MAPOUT.EQ.401) GO TO 40 - IF (MAPOUT.EQ.402) GO TO 40 - IF (MAPOUT.EQ.403) GO TO 40 -C -C LOLA MAPS -C - IF (MAPOUT.EQ.21) GO TO 50 - IF (MAPOUT.EQ.22) GO TO 50 - IF (MAPOUT.EQ.29) GO TO 50 - IF (MAPOUT.EQ.30) GO TO 50 - IF (MAPOUT.EQ.33) GO TO 50 - IF (MAPOUT.EQ.34) GO TO 50 - IF (MAPOUT.EQ.45) GO TO 50 - IF (MAPOUT.EQ.46) GO TO 50 - IF (MAPOUT.EQ.500) GO TO 50 - IF (MAPOUT.EQ.501) GO TO 50 -C -C NO MATCH - ERROR -C - IER = 2 - RETURN -C -C SET LOGICAL FLAGS -C - 40 LOLAOU = .FALSE. - POLAOU = .TRUE. - GO TO 60 -C - 50 LOLAOU = .TRUE. - POLAOU = .FALSE. -C -C GO TO DIFFERENT SECTIONS FOR IN/OUT OPTIONS -C - 60 IF (POLAIN) GO TO 1000 - IF (LOLAIN) GO TO 5000 -C -C ################################################################## -C ################################################################## -C -C THIS SECTION FOR POLAR STEREOGRAPHIC INPUT MAPS -C -C SUBDIVIDED FOR OUTPUT TYPE -C - 1000 IF (LOLAOU) GO TO 3000 -C -C POLAR STEREO TO POLAR STEREO -C USE HOWCROFTS FIELD TRANSFORMER -C ORIENT IS DEGREES OF ROTATION FROM NMC STANDARD -C (80 DEG CENTER VERTIVAL) TO INPUT GRID (POSITIVE ANTICLOCKWISE) -C - IF (MAPIN.EQ. 5) GO TO 1005 - IF (MAPIN.EQ.25) GO TO 1025 - IF (MAPIN.EQ.26) GO TO 1026 - IF (MAPIN.EQ.27) GO TO 1027 - IF (MAPIN.EQ.28) GO TO 1027 - IF (MAPIN.EQ.49) GO TO 1049 - IF (MAPIN.EQ.50) GO TO 1049 - IF (MAPIN.EQ.51) GO TO 1051 - IF (MAPIN.EQ.55) GO TO 1055 - IF (MAPIN.EQ.56) GO TO 1056 - IF (MAPIN.EQ.60) GO TO 1060 - IF (MAPIN.EQ.87) GO TO 1087 - IF (MAPIN.EQ.100) GO TO 1100 - IF (MAPIN.EQ.101) GO TO 1101 - IF (MAPIN.EQ.105) GO TO 1105 - IF (MAPIN.EQ.106) GO TO 1106 - IF (MAPIN.EQ.107) GO TO 1107 - IER = 1 - RETURN -C - 1005 IMAXIN =53 - JMAXIN = 57 - COMIIN = 27. - COMJIN = 49. - ORIENT = -25. - XMESH = 190.5 - GO TO 2000 -C - 1025 IMAXIN = 53 - JMAXIN = 57 - COMIIN = 27. - COMJIN = 29. - ORIENT = 0. - XMESH = 381. - GO TO 2000 -C - 1026 IMAXIN = 53 - JMAXIN = 45 - COMIIN = 27. - COMJIN = 49. - ORIENT = -25. - XMESH = 190.5 - GO TO 2000 -C - 1027 IMAXIN = 65 - JMAXIN = 65 - COMIIN = 33. - COMJIN = 33. - ORIENT = 0. - XMESH = 381. - GO TO 2000 -C - 1049 IMAXIN = 129 - JMAXIN = 129 - COMIIN = 65. - COMJIN = 65. - ORIENT = 0. - XMESH = 190.5 - GOTO 2000 -C - 1051 IMAXIN = 129 - JMAXIN = 129 - COMIIN = 65. - COMJIN = 65. - ORIENT = -25. - XMESH = 190.5 - GOTO 2000 -C - 1055 IMAXIN = 87 - JMAXIN = 71 - COMIIN = 44. - COMJIN = 38. - ORIENT = -25. - XMESH = 254. - GOTO 2000 -C - 1056 IMAXIN = 87 - JMAXIN = 71 - COMIIN = 40. - COMJIN = 73. - ORIENT = -25. - XMESH = 127. - GOTO 2000 -C - 1060 IMAXIN= 57 - JMAXIN = 57 - COMIIN = 29. - COMJIN = 49. - ORIENT = -25. - XMESH = 190.5 - GO TO 2000 -C - 1087 IMAXIN= 81 - JMAXIN = 62 - COMIIN = 31.91 - COMJIN = 112.53 - ORIENT = -25. - XMESH = 68.153 - GO TO 2000 -C - 1100 IMAXIN = 83 - JMAXIN = 83 - COMIIN = 40.5 - COMJIN = 88.5 - ORIENT = -25. - XMESH = 91.452 - GO TO 2000 -C - 1101 IMAXIN = 113 - JMAXIN = 91 - COMIIN = 58.5 - COMJIN = 92.5 - ORIENT = -25. - XMESH = 91.452 - GO TO 2000 -C - 1105 IMAXIN = 83 - JMAXIN = 83 - COMIIN = 40.5 - COMJIN = 88.5 - ORIENT = -25. - XMESH = 90.75464 - GO TO 2000 -C - 1106 IMAXIN = 165 - JMAXIN = 117 - COMIIN = 80.0 - COMJIN = 176.0 - ORIENT = -25. - XMESH = 45.37732 - GO TO 2000 -C - 1107 IMAXIN = 120 - JMAXIN = 92 - COMIIN = 46.0 - COMJIN = 167.0 - ORIENT = -25. - XMESH = 45.37732 - GO TO 2000 -C -C SELECT I, J, DILATION, ROTATION, AND COMMON POINT (POLE) OUTPUT -C DILATE = XMESHOUT / XMESHIN -C IN THE FOLLOWING, ROT IS THE ROTATION FROM THE INPUT TO -C THE OUTPUT GRID - NOT THE ORIENTATION OF THE OUT-GRID -C - 2000 IF (MAPOUT.EQ. 5) GO TO 2005 - IF (MAPOUT.EQ.25) GO TO 2025 - IF (MAPOUT.EQ.26) GO TO 2026 - IF (MAPOUT.EQ.27) GO TO 2027 - IF (MAPOUT.EQ.28) GO TO 2027 - IF (MAPOUT.EQ.49) GO TO 2049 - IF (MAPOUT.EQ.50) GO TO 2049 - IF (MAPOUT.EQ.51) GO TO 2051 - IF (MAPOUT.EQ.55) GO TO 2055 - IF (MAPOUT.EQ.56) GO TO 2056 - IF (MAPOUT.EQ.60) GO TO 2060 - IF (MAPOUT.EQ.87) GO TO 2087 - IF (MAPOUT.EQ.100) GO TO 2100 - IF (MAPOUT.EQ.101) GO TO 2101 - IF (MAPOUT.EQ.105) GO TO 2105 - IF (MAPOUT.EQ.106) GO TO 2106 - IF (MAPOUT.EQ.107) GO TO 2107 - IF (MAPOUT.EQ.400) GO TO 2400 - IF (MAPOUT.EQ.401) GO TO 2401 - IF (MAPOUT.EQ.402) GO TO 2402 - IF (MAPOUT.EQ.403) GO TO 2403 - IER = 3 - RETURN -C - 2005 IMAXOU = 53 - JMAXOU = 57 - DILAT = 190.5/XMESH - ROT = -25. - ORIENT - COMIOU = 27. - COMJOU = 49. - GO TO 2700 -C - 2025 IMAXOU = 53 - JMAXOU = 57 - DILAT = 381./XMESH - ROT = 0. - ORIENT - COMIOU = 27. - COMJOU = 29. - GO TO 2700 -C - 2026 IMAXOU = 53 - JMAXOU = 45 - DILAT = 190.5/XMESH - ROT = -25. - ORIENT - COMIOU = 27. - COMJOU = 49. - GO TO 2700 -C - 2027 IMAXOU = 65 - JMAXOU = 65 - DILAT = 381./XMESH - ROT = 0. - ORIENT - COMIOU = 33. - COMJOU = 33. - GO TO 2700 -C - 2049 IMAXOU = 129 - JMAXOU = 129 - DILAT = 190.5/XMESH - ROT = 0. - ORIENT - COMIOU = 65. - COMJOU = 65. - GOTO 2700 -C - 2051 IMAXOU = 129 - JMAXOU = 129 - DILAT = 190.5/XMESH - ROT = -25. - ORIENT - COMIOU = 65. - COMJOU = 65. - GOTO 2700 -C - 2055 IMAXOU = 87 - JMAXOU = 71 - DILAT = 254./XMESH - ROT = -25. - ORIENT - COMIOU = 44. - COMJOU = 38. - GOTO 2700 -C - 2056 IMAXOU = 87 - JMAXOU = 71 - DILAT = 127./XMESH - ROT = -25. - ORIENT - COMIOU = 40. - COMJOU = 73. - GOTO 2700 -C - 2060 IMAXOU = 57 - JMAXOU = 57 - DILAT = 190.5/XMESH - ROT = -25. - ORIENT - COMIOU = 29. - COMJOU = 49. - GO TO 2700 -C - 2087 IMAXOU = 81 - JMAXOU = 62 - DILAT = 68.153/XMESH - ROT = -25. - ORIENT - COMIOU = 31.91 - COMJOU = 112.53 - GO TO 2700 -C - 2100 IMAXOU = 83 - JMAXOU = 83 - DILAT = 91.452/XMESH - ROT = -25. - ORIENT - COMIOU = 40.5 - COMJOU = 88.5 - GO TO 2700 -C - 2101 IMAXOU = 113 - JMAXOU = 91 - DILAT = 91.452/XMESH - ROT = -25. - ORIENT - COMIOU = 58.5 - COMJOU = 92.5 - GO TO 2700 -C - 2105 IMAXOU = 83 - JMAXOU = 83 - DILAT = 90.75464/XMESH - ROT = -25. - ORIENT - COMIOU = 40.5 - COMJOU = 88.5 - GO TO 2700 -C - 2106 IMAXOU = 165 - JMAXOU = 117 - DILAT = 45.37732/XMESH - ROT = -25. - ORIENT - COMIOU = 80.0 - COMJOU = 176.0 - GO TO 2700 -C - 2107 IMAXOU = 120 - JMAXOU = 92 - DILAT = 45.37732/XMESH - ROT = -25. - ORIENT - COMIOU = 46.0 - COMJOU = 167.0 - GO TO 2700 -C - 2400 IMAXOU = 39 - JMAXOU = 39 - DILAT = 508./ XMESH - ROT = 0. - ORIENT - COMIOU = 20. - COMJOU = 20. - GO TO 2700 -C - 2401 IMAXOU = 25 - JMAXOU = 35 - DILAT = 254./XMESH - ROT = -25. + 90. - ORIENT - COMIOU =31.75 - COMJOU = 18. - GO TO 2700 -C - 2402 IMAXOU = 97 - JMAXOU = 97 - DILAT = 254./XMESH - ROT = -25. - ORIENT - COMIOU = 49. - COMJOU = 49. - GOTO 2700 -C - 2403 IMAXOU = 97 - JMAXOU = 97 - DILAT = 254./XMESH - ROT = 0. - ORIENT - COMIOU = 49. - COMJOU = 49. - GOTO 2700 -C - 2700 CALL W3FT00 - 1 (FIELD, DATA, IMAXIN, JMAXIN, IMAXOU, JMAXOU, - 2 COMIIN, COMJIN, COMIOU, COMJOU, - 3 DILAT, ROT, INTERP) - RETURN -C -C ################################################################## -C -C HERE FOR POLAR STEREO TO LO/LA -C - 3000 IF (MAPIN.EQ. 5) GO TO 3005 - IF (MAPIN.EQ.25) GO TO 3025 - IF (MAPIN.EQ.26) GO TO 3026 - IF (MAPIN.EQ.27) GO TO 3027 - IF (MAPIN.EQ.28) GO TO 3027 - IF (MAPIN.EQ.49) GO TO 3049 - IF (MAPIN.EQ.50) GO TO 3049 - IF (MAPIN.EQ.51) GO TO 3051 - IF (MAPIN.EQ.55) GO TO 3055 - IF (MAPIN.EQ.56) GO TO 3056 - IF (MAPIN.EQ.60) GO TO 3060 - IF (MAPIN.EQ.87) GO TO 3087 - IF (MAPIN.EQ.100) GO TO 3100 - IF (MAPIN.EQ.101) GO TO 3101 - IF (MAPIN.EQ.105) GO TO 3105 - IF (MAPIN.EQ.106) GO TO 3106 - IF (MAPIN.EQ.107) GO TO 3107 -C - 3005 XMESH = 190.5 - IMAXIN = 53 - JMAXIN = 57 - NTHSTH = 1 - POLEI = 27. - POLEJ = 49. - ORIENT = 105. - GO TO 4000 -C - 3025 XMESH = 381. - IMAXIN = 53 - JMAXIN = 57 - NTHSTH = 2 - POLEI = 27. - POLEJ = 29. - GO TO 4000 -C - 3026 XMESH = 190.5 - IMAXIN = 53 - JMAXIN = 45 - NTHSTH = 1 - POLEI = 27. - POLEJ = 49. - ORIENT = 105. - GO TO 4000 -C - 3027 XMESH = 381. - IMAXIN = 65 - JMAXIN = 65 - NTHSTH = 1 - IF (MAPIN.EQ.28) NTHSTH = 2 - POLEI = 33. - POLEJ = 33. - ORIENT = 80. - GO TO 4000 -C - 3049 XMESH = 190.5 - IMAXIN = 129 - JMAXIN = 129 - NTHSTH = 1 - IF (MAPIN.EQ.50) NTHSTH=2 - POLEI = 65. - POLEJ = 65. - ORIENT = 80. - GOTO 4000 -C - 3051 XMESH = 190.5 - IMAXIN = 129 - JMAXIN = 129 - NTHSTH = 1 - POLEI = 65. - POLEJ = 65. - ORIENT = 105. - GOTO 4000 -C - 3055 XMESH = 254. - IMAXIN = 87 - JMAXIN = 71 - NTHSTH = 1 - POLEI = 44. - POLEJ = 38. - ORIENT = 105. - GOTO 4000 -C - 3056 XMESH = 127. - IMAXIN = 87 - JMAXIN = 71 - NTHSTH = 1 - POLEI = 40. - POLEJ = 73. - ORIENT = 105. - GOTO 4000 -C - 3060 XMESH = 190.5 - IMAXIN = 57 - JMAXIN = 57 - NTHSTH = 1 - POLEI = 29. - POLEJ = 49. - ORIENT = 105. - GO TO 4000 -C - 3087 XMESH = 68.153 - IMAXIN = 81 - JMAXIN = 62 - NTHSTH = 1 - POLEI = 31.91 - POLEJ = 112.53 - ORIENT = 105. - GO TO 4000 -C - 3100 XMESH = 91.452 - IMAXIN = 83 - JMAXIN = 83 - NTHSTH = 1 - POLEI = 40.5 - POLEJ = 88.5 - ORIENT = 105. - GO TO 4000 -C - 3101 XMESH = 91.452 - IMAXIN = 113 - JMAXIN = 91 - NTHSTH = 1 - POLEI = 58.5 - POLEJ = 92.5 - ORIENT = 105. - GO TO 4000 -C - 3105 XMESH = 90.75464 - IMAXIN = 83 - JMAXIN = 83 - NTHSTH = 1 - POLEI = 40.5 - POLEJ = 88.5 - ORIENT = 105. - GO TO 4000 -C - 3106 XMESH = 45.37732 - IMAXIN = 165 - JMAXIN = 117 - NTHSTH = 1 - POLEI = 80.0 - POLEJ = 176.0 - ORIENT = 105. - GO TO 4000 -C - 3107 XMESH = 45.37732 - IMAXIN = 120 - JMAXIN = 92 - NTHSTH = 1 - POLEI = 46.0 - POLEJ = 167.0 - ORIENT = 105. - GO TO 4000 -C -C SELECT OUTPUT LO/LA VARIATIONS -C - 4000 IF (MAPOUT.EQ.21) GO TO 4021 - IF (MAPOUT.EQ.22) GO TO 4021 - IF (MAPOUT.EQ.29) GO TO 4029 - IF (MAPOUT.EQ.30) GO TO 4029 - IF (MAPOUT.EQ.33) GO TO 4033 - IF (MAPOUT.EQ.34) GO TO 4033 - IF (MAPOUT.EQ.45) GO TO 4045 - IF (MAPOUT.EQ.46) GO TO 4045 - IF (MAPOUT.EQ.500) GO TO 4500 - IF (MAPOUT.EQ.501) GO TO 4501 - IER = 4 - RETURN -C - 4021 IMINOU = 1 - JMINOU = 1 - IMAXOU = 73 - JMAXOU = 19 - DEG = 5.0 - GO TO 4700 -C - 4029 IMINOU = 1 - IMAXOU = 145 - JMINOU = 1 - JMAXOU = 37 - DEG = 2.5 - GO TO 4700 -C - 4033 IMINOU = 1 - IMAXOU = 181 - JMINOU = 1 - JMAXOU = 46 - DEG = 2.0 - GO TO 4700 -C - 4045 IMINOU = 1 - IMAXOU = 97 - JMINOU = 1 - JMAXOU = 25 - DEG = 3.75 - GOTO 4700 -C - 4500 IMINOU = 93 - IMAXOU = 117 - JMINOU = 1 - JMAXOU = 37 - DEG = 2.5 - GO TO 4700 -C - 4501 IMINOU = 116 - IMAXOU = 140 - JMINOU = 1 - JMAXOU = 46 - DEG = 2.0 - GO TO 4700 -C -C FIND INPUT POLA I,J FOR DESIRED LOLA OUTPUT POINTS -C - 4700 IJOUT = 0 - DO 4740 J = JMINOU, JMAXOU - XLAT = (J-1) * DEG - IF (NTHSTH.EQ.2) XLAT = XLAT - 90. - DO 4740 I = IMINOU, IMAXOU - ELON = (I-1) * DEG - WLON = AMOD(360. - ELON, 360.) - GO TO (4710, 4720), NTHSTH - 4710 CALL W3FB04(XLAT, WLON, XMESH, ORIENT, XI, XJ) - GO TO 4730 - 4720 CALL W3FB02(XLAT, WLON, XMESH, XI, XJ) - 4730 XIIN = XI + POLEI - XJIN = XJ + POLEJ -C -C MACDONALDS SUPER GENERAL INTERPOLATOR -C IN WHICH D = FIELD(XIIN, XJIN) -C - CALL W3FT01 - 1 (XIIN, XJIN, FIELD, D, IMAXIN, JMAXIN, 0, INTERP) - IJOUT = IJOUT + 1 - DATA(IJOUT) = D - 4740 CONTINUE - RETURN -C -C ################################################################## -C ################################################################## -C -C THIS SECTION FOR LOLA INPUT MAP -C -C SELCT OUTPUT TYPE -C - 5000 IF (LOLAOU) GO TO 7000 -C -C LOLA TO POLA -C SELECT INPUT INFO -C (THIS PATTERN CAN BE USED WITH POLA INPUT, TOO - TRY IT -C - IF (MAPIN.EQ.21) GO TO 5021 - IF (MAPIN.EQ.22) GO TO 5021 - IF (MAPIN.EQ.29) GO TO 5029 - IF (MAPIN.EQ.30) GO TO 5029 - IF (MAPIN.EQ.33) GO TO 5033 - IF (MAPIN.EQ.34) GO TO 5033 - IF (MAPIN.EQ.45) GO TO 5045 - IF (MAPIN.EQ.46) GO TO 5045 - IER = 5 - RETURN -C - 5021 IMAXIN = 73 - JMAXIN = 19 - DEG = 5.0 - NTHSTH = 1 - IF (MAPIN.EQ.22) NTHSTH = 2 - GO TO 6000 -C - 5029 IMAXIN = 145 - JMAXIN = 37 - DEG = 2.5 - NTHSTH = 1 - IF (MAPIN.EQ.30) NTHSTH = 2 - GO TO 6000 -C - 5033 IMAXIN = 181 - JMAXIN = 46 - DEG = 2.0 - NTHSTH = 1 - IF (MAPIN.EQ.34) NTHSTH = 2 - GO TO 6000 -C - 5045 IMAXIN = 97 - JMAXIN = 25 - DEG = 3.75 - NTHSTH = 1 - IF (MAPIN.EQ.46) NTHSTH = 2 - GOTO 6000 -C -C SELECT OUTPUT POLA VARIETY -C ROT INDICATES HOW MANY DEGREES THE POLA GRID IS TO BE ROTATED -C (POSITIVE COUNTER-CLOCKWISE) FROM THE NMC 'STANDARD' -C OF 80 DEG WEST AT THE BOTTOM (OR TOP IF SOUTHERN HEMISPHERE) -C - 6000 IF (MAPOUT.EQ. 5) GO TO 6005 - IF (MAPOUT.EQ.25) GO TO 6025 - IF (MAPOUT.EQ.26) GO TO 6026 - IF (MAPOUT.EQ.27) GO TO 6027 - IF (MAPOUT.EQ.28) GO TO 6027 - IF (MAPOUT.EQ.49) GO TO 6049 - IF (MAPOUT.EQ.50) GO TO 6049 - IF (MAPOUT.EQ.51) GO TO 6051 - IF (MAPOUT.EQ.55) GO TO 6055 - IF (MAPOUT.EQ.56) GO TO 6056 - IF (MAPOUT.EQ.60) GO TO 6060 - IF (MAPOUT.EQ.87) GO TO 6087 - IF (MAPOUT.EQ.100) GO TO 6100 - IF (MAPOUT.EQ.101) GO TO 6101 - IF (MAPOUT.EQ.105) GO TO 6105 - IF (MAPOUT.EQ.106) GO TO 6106 - IF (MAPOUT.EQ.107) GO TO 6107 - IF (MAPOUT.EQ.400) GO TO 6400 - IF (MAPOUT.EQ.401) GO TO 6401 - IF (MAPOUT.EQ.402) GO TO 6402 - IF (MAPOUT.EQ.403) GO TO 6403 - IER = 6 - RETURN -C - 6005 IMAXOU = 53 - JMAXOU = 57 - XMESH = 190.5 - ROT = -25. - POLEI = 27. - POLEJ = 49. - GO TO 6700 -C - 6025 IMAXOU = 53 - JMAXOU = 57 - XMESH = 381. - ROT = 0. - POLEI = 27. - POLEJ = 29. - GO TO 6700 -C - 6026 IMAXOU = 53 - JMAXOU = 45 - XMESH = 190.5 - ROT = -25. - POLEI = 27. - POLEJ = 49. - GO TO 6700 -C - 6027 IMAXOU = 65 - JMAXOU = 65 - XMESH = 381. - ROT = 0. - POLEI = 33. - POLEJ = 33. - GO TO 6700 -C - 6049 IMAXOU = 129 - JMAXOU = 129 - XMESH = 190.5 - ROT = 0. - POLEI = 65. - POLEJ = 65. - GOTO 6700 -C - 6051 IMAXOU = 129 - JMAXOU = 129 - XMESH = 190.5 - ROT = -25. - POLEI = 65. - POLEJ = 65. - GOTO 6700 -C - 6055 IMAXOU = 87 - JMAXOU = 71 - XMESH = 254. - ROT = -25. - POLEI = 44. - POLEJ = 38. - GOTO 6700 -C - 6056 IMAXOU = 87 - JMAXOU = 71 - XMESH = 127. - ROT = -25. - POLEI = 40. - POLEJ = 73. - GOTO 6700 -C - 6060 IMAXOU = 57 - JMAXOU = 57 - XMESH = 190.5 - ROT = -25. - POLEI = 29. - POLEJ = 49. - GO TO 6700 -C - 6087 IMAXOU = 81 - JMAXOU = 62 - XMESH = 68.153 - ROT = -25. - POLEI = 31.91 - POLEJ = 112.53 - GO TO 6700 -C - 6100 IMAXOU = 83 - JMAXOU = 83 - XMESH = 91.452 - ROT = -25. - POLEI = 40.5 - POLEJ = 88.5 - GO TO 6700 -C - 6101 IMAXOU = 113 - JMAXOU = 91 - XMESH = 91.452 - ROT = -25. - POLEI = 58.5 - POLEJ = 92.5 - GO TO 6700 -C - 6105 IMAXOU = 83 - JMAXOU = 83 - XMESH = 90.75464 - ROT = -25. - POLEI = 40.5 - POLEJ = 88.5 - GO TO 6700 -C - 6106 IMAXOU = 165 - JMAXOU = 117 - XMESH = 45.37732 - ROT = -25. - POLEI = 80.0 - POLEJ = 176.0 - GO TO 6700 -C - 6107 IMAXOU = 120 - JMAXOU = 92 - XMESH = 45.37732 - ROT = -25. - POLEI = 46.0 - POLEJ = 167.0 - GO TO 6700 -C - 6400 IMAXOU = 39 - JMAXOU = 39 - XMESH = 508. - ROT = 0. - POLEI = 20. - POLEJ = 20. - GO TO 6700 -C -C THIS ONE GETS SPECIAL TREATMENT BECAUSE WE ARE -C INTERCHANGING ROWS AND COLUMNS FOR GRIDPRINT AFTER INTERPOLATION -C (ACTUALLY IT IS DONE ALL AT ONCE) -C - 6401 IMAXOU = 25 - JMAXOU = 35 - XMESH = 254. - ROT = -25. - POLEI = 18. - POLEJ = 31.75 -C - IJOUT = 0 - DO 64011 J=1,JMAXOU - XI = JMAXOU - J + 1 - XXI = XI - POLEI - DO 64011 I = 1,IMAXOU - XJ = I - XXJ = XJ - POLEJ - CALL W3FB01(XXI, XXJ, XMESH, XLAT, WLON) - WLON = WLON - ROT - IF (WLON.GT.360.) WLON = WLON - 360. - IF (WLON.LT.0.) WLON = WLON + 360. - XIIN = (360.-WLON)/DEG + 1. - XJIN = XLAT/DEG + 1. - CALL W3FT01 - 1 (XIIN, XJIN, FIELD, D, IMAXIN, JMAXIN, 1, INTERP) - IJOUT = IJOUT + 1 - DATA(IJOUT) = D -64011 CONTINUE - RETURN -C - 6402 IMAXOU = 97 - JMAXOU = 97 - XMESH = 254. - ROT = -25. - POLEI = 49. - POLEJ = 49. - GOTO 6700 -C - 6403 IMAXOU = 97 - JMAXOU = 97 - XMESH = 254. - ROT = 0. - POLEI = 49. - POLEJ = 49. - GOTO 6700 -C -C FIND INPUT LOLA I,J FOR DESIRED POLA OUTPUT POINTS -C - 6700 IJOUT = 0 - DO 6740 J=1,JMAXOU - XJ = J - POLEJ - DO 6740 I=1,IMAXOU - XI = I - POLEI - GOTO (6710, 6720), NTHSTH - 6710 CALL W3FB01(XI, XJ, XMESH, XLAT, WLON) - WLON = WLON - ROT - GO TO 6730 - 6720 CALL W3FB03(XI, XJ, XMESH, XLAT, WLON) - WLON = WLON + ROT - XLAT = XLAT + 90. - 6730 IF (WLON.GT.360.) WLON = WLON - 360. - IF (WLON.LT.0.) WLON = WLON + 360. - XIIN = (360.-WLON)/DEG + 1. - XJIN = XLAT/DEG + 1. - CALL W3FT01 - 1 (XIIN, XJIN, FIELD, D, IMAXIN, JMAXIN, 1, INTERP) - IJOUT = IJOUT + 1 - DATA(IJOUT) = D - 6740 CONTINUE - RETURN -C -C ################################################################## -C -C LOLA TO LOLA -C -C SELECT INPUT GRID INFO -C - 7000 IF (MAPIN.EQ.21) GO TO 7021 - IF (MAPIN.EQ.22) GO TO 7021 - IF (MAPIN.EQ.29) GO TO 7029 - IF (MAPIN.EQ.30) GO TO 7029 - IF (MAPIN.EQ.33) GO TO 7033 - IF (MAPIN.EQ.34) GO TO 7033 - IF (MAPIN.EQ.45) GOTO 7045 - IF (MAPIN.EQ.46) GOTO 7045 - IER = 7 - RETURN -C - 7021 IMAXIN = 73 - JMAXIN = 19 - DEGIN = 5.0 - GO TO 8000 -C - 7029 IMAXIN = 145 - JMAXIN = 37 - DEGIN = 2.5 - GO TO 8000 -C - 7033 IMAXIN = 181 - JMAXIN = 46 - DEGIN = 2.0 - GO TO 8000 -C - 7045 IMAXIN = 97 - JMAXIN = 25 - DEGIN = 3.75 - GOTO 8000 -C -C SELECT OUTPUT LOLA GRID -C - 8000 IF (MAPOUT.EQ.21) GO TO 8021 - IF (MAPOUT.EQ.22) GO TO 8021 - IF (MAPOUT.EQ.29) GO TO 8029 - IF (MAPOUT.EQ.30) GO TO 8029 - IF (MAPOUT.EQ.33) GO TO 8033 - IF (MAPOUT.EQ.34) GO TO 8033 - IF (MAPOUT.EQ.45) GO TO 8045 - IF (MAPOUT.EQ.46) GO TO 8045 - IF (MAPOUT.EQ.500) GO TO 8500 - IF (MAPOUT.EQ.501) GO TO 8501 - IER = 8 - RETURN -C - 8021 IMINOU = 1 - IMAXOU = 73 - JMINOU = 1 - JMAXOU = 19 - DEGOU = 5. - GO TO 8700 -C - 8029 IMINOU = 1 - IMAXOU = 145 - JMINOU = 1 - JMAXOU = 37 - DEGOU = 2.5 - GO TO 8700 -C - 8033 IMINOU = 1 - IMAXOU = 181 - JMINOU = 1 - JMAXOU = 46 - DEGOU = 2.0 - GO TO 8700 -C - 8045 IMINOU = 1 - IMAXOU = 97 - JMINOU = 1 - JMAXOU = 25 - DEGOU = 3.75 - GOTO 8700 -C - 8500 IMINOU = 93 - IMAXOU = 117 - JMINOU = 1 - JMAXOU = 37 - DEGOU = 2.5 - GO TO 8700 -C - 8501 IMINOU = 116 - IMAXOU = 140 - JMINOU = 1 - JMAXOU = 46 - DEGOU = 2.0 - GO TO 8700 -C - 8700 IJOUT = 0 - RDEG = DEGOU/DEGIN - DO 8710 J=JMINOU, JMAXOU - XJIN = (J-1)*RDEG + 1. - DO 8710 I=IMINOU, IMAXOU - XIIN = (I-1)*RDEG + 1. - CALL W3FT01 - 1 (XIIN, XJIN, FIELD, D, IMAXIN, JMAXIN, 1, INTERP) - IJOUT = IJOUT + 1 - DATA(IJOUT) = D - 8710 CONTINUE - RETURN -C - END diff --git a/external/w3nco/v2.0.6/src/w3kind.f b/external/w3nco/v2.0.6/src/w3kind.f deleted file mode 100644 index 53487942a..000000000 --- a/external/w3nco/v2.0.6/src/w3kind.f +++ /dev/null @@ -1,34 +0,0 @@ -!----------------------------------------------------------------------- - subroutine w3kind(kindreal,kindint) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3KIND RETURN THE real kind and integer kind used -! in w3 lib -! AUTHOR: Jun Wang DATE: 11-06-24 -! -! ABSTRACT: THIS SUBPROGRAM RETURNS THE REAL KIND AND THE INTEGER KIND -! THAT THE W3 LIB IS COMPILED WITH. -! -! PROGRAM HISTORY LOG: -! 2011-06-24 Jun Wang -! -! USAGE: CALL W3KIND(kindreal,kindint) -! -! OUTPUT VARIABLES: -! KINDREAL INTEGER KIND OF REAL NUMBER IN W3 LIB -! KINDINTL INTEGER KIND OF INTEGER NUMBER IN W3 LIB -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - IMPLICIT NONE -! - integer,intent(out) :: kindreal,kindint -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! get real kind from a real number - kindreal=kind(1.0) - kindint=kind(1) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end - diff --git a/external/w3nco/v2.0.6/src/w3locdat.f b/external/w3nco/v2.0.6/src/w3locdat.f deleted file mode 100644 index d88094ea8..000000000 --- a/external/w3nco/v2.0.6/src/w3locdat.f +++ /dev/null @@ -1,43 +0,0 @@ -!----------------------------------------------------------------------- - subroutine w3locdat(idat) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3LOCDAT RETURN THE LOCAL DATE AND TIME -! AUTHOR: MARK IREDELL ORG: WP23 DATE: 98-01-05 -! -! ABSTRACT: THIS SUBPROGRAM RETURNS THE LOCAL DATE AND TIME -! IN THE NCEP ABSOLUTE DATE AND TIME DATA STRUCTURE. -! -! PROGRAM HISTORY LOG: -! 98-01-05 MARK IREDELL -! 1999-04-28 Gilbert - added a patch to check for the proper -! UTC offset. Needed until the IBM bug -! in date_and_time is fixed. The patch -! can then be removed. See comments in -! the section blocked with "&&&&&&&&&&&". -! 1999-08-12 Gilbert - Changed so that czone variable is saved -! and the system call is only done for -! first invocation of this routine. -! -! USAGE: CALL W3LOCDAT(IDAT) -! -! OUTPUT VARIABLES: -! IDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! -! SUBPROGRAMS CALLED: -! DATE_AND_TIME FORTRAN 90 SYSTEM DATE INTRINSIC -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - integer idat(8) - character cdate*8,ctime*10,czone*5 -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! get local date and time but use the character time zone - call date_and_time(cdate,ctime,czone,idat) - read(czone,'(i5)') idat(4) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end diff --git a/external/w3nco/v2.0.6/src/w3movdat.f b/external/w3nco/v2.0.6/src/w3movdat.f deleted file mode 100644 index 8959198fe..000000000 --- a/external/w3nco/v2.0.6/src/w3movdat.f +++ /dev/null @@ -1,53 +0,0 @@ -!----------------------------------------------------------------------- - subroutine w3movdat(rinc,idat,jdat) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3MOVDAT RETURN A DATE FROM A TIME INTERVAL AND DATE -! AUTHOR: MARK IREDELL ORG: WP23 DATE: 98-01-05 -! -! ABSTRACT: THIS SUBPROGRAM RETURNS THE DATE AND TIME THAT IS A GIVEN -! NCEP RELATIVE TIME INTERVAL FROM AN NCEP ABSOLUTE DATE AND TIME. -! THE OUTPUT IS IN THE NCEP ABSOLUTE DATE AND TIME DATA STRUCTURE. -! -! PROGRAM HISTORY LOG: -! 98-01-05 MARK IREDELL -! -! USAGE: CALL W3MOVDAT(RINC,IDAT,JDAT) -! -! INPUT VARIABLES: -! RINC REAL (5) NCEP RELATIVE TIME INTERVAL -! (DAYS, HOURS, MINUTES, SECONDS, MILLISECONDS) -! IDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! -! OUTPUT VARIABLES: -! JDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! (JDAT IS LATER THAN IDAT IF TIME INTERVAL IS POSITIVE.) -! -! SUBPROGRAMS CALLED: -! IW3JDN COMPUTE JULIAN DAY NUMBER -! W3FS26 YEAR, MONTH, DAY FROM JULIAN DAY NUMBER -! W3REDDAT REDUCE A TIME INTERVAL TO A CANONICAL FORM -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - real rinc(5) - integer idat(8),jdat(8) - real rinc1(5),rinc2(5) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! add the interval to the input time of day and put into reduced form -! and then compute new date using julian day arithmetic. - rinc1(1)=rinc(1) - rinc1(2:5)=rinc(2:5)+idat(5:8) - call w3reddat(-1,rinc1,rinc2) - jldayn=iw3jdn(idat(1),idat(2),idat(3))+nint(rinc2(1)) - call w3fs26(jldayn,jdat(1),jdat(2),jdat(3),jdow,jdoy) - jdat(4)=idat(4) - jdat(5:8)=nint(rinc2(2:5)) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end diff --git a/external/w3nco/v2.0.6/src/w3nogds.f b/external/w3nco/v2.0.6/src/w3nogds.f deleted file mode 100644 index f08d3d9ea..000000000 --- a/external/w3nco/v2.0.6/src/w3nogds.f +++ /dev/null @@ -1,446 +0,0 @@ - SUBROUTINE W3NOGDS(ITYPE,FLD,IFLD,IBITL, - & IPFLAG,ID,PDS, - & IGFLAG,IGRID,IGDS,ICOMP, - & IBFLAG,IBMAP,IBLEN,IBDSFL, - & NPTS,KBUF,ITOT,JERR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3NOGDS MAKE A COMPLETE GRIB MESSAGE -C PRGMMR: FARLEY ORG: NMC421 DATE:94-11-22 -C -C ABSTRACT: MAKES A COMPLETE GRIB MESSAGE FROM A USER SUPPLIED -C ARRAY OF FLOATING POINT OR INTEGER DATA. THE USER HAS THE -C OPTION OF SUPPLYING THE PDS OR AN INTEGER ARRAY THAT WILL BE -C USED TO CREATE A PDS (WITH W3FI68). THE USER MUST ALSO -C SUPPLY OTHER NECESSARY INFO; SEE USAGE SECTION BELOW. -C -C PROGRAM HISTORY LOG: -C 97-02-24 M. FARLEY MODIFIED W3FI72 - this routine allows for -C NO GDS (errors in W3FI71 for GRIB grids -C 21-26, 61-64 forced the need for this routine). -C 98-06-24 Gilbert Added number of gridpoint values for grids -C 61-64, needed when igflag=2 ( no gds ). -C 98-12-21 Gilbert Replaced Function ICHAR with mova2i. -C -C USAGE: CALL W3NOGDS(ITYPE,FLD,IFLD,IBITL, -C & IPFLAG,ID,PDS, -C & IGFLAG,IGRID,IGDS,ICOMP, -C & IBFLAG,IBMAP,IBLEN,IBDSFL, -C & IBDSFL, -C & NPTS,KBUF,ITOT,JERR) -C -C INPUT ARGUMENT LIST: -C ITYPE - 0 = FLOATING POINT DATA SUPPLIED IN ARRAY 'FLD' -C 1 = INTEGER DATA SUPPLIED IN ARRAY 'IFLD' -C FLD - REAL ARRAY OF DATA (AT PROPER GRIDPOINTS) TO BE -C CONVERTED TO GRIB FORMAT IF ITYPE=0. -C SEE REMARKS #1 & 2. -C IFLD - INTEGER ARRAY OF DATA (AT PROPER GRIDPOINTS) TO BE -C CONVERTED TO GRIB FORMAT IF ITYPE=1. -C SEE REMARKS #1 & 2. -C IBITL - 0 = COMPUTER COMPUTES LENGTH FOR PACKING DATA FROM -C POWER OF 2 (NUMBER OF BITS) BEST FIT OF DATA -C USING 'VARIABLE' BIT PACKER W3FI58. -C 8, 12, ETC. COMPUTER RESCALES DATA TO FIT INTO THAT -C 'FIXED' NUMBER OF BITS USING W3FI59. -C SEE REMARKS #3. -C -C IPFLAG - 0 = MAKE PDS FROM USER SUPPLIED ARRAY (ID) -C 1 = USER SUPPLYING PDS -C NOTE: IF PDS IS GREATER THAN 30, USE IPLFAG=1. -C THE USER COULD CALL W3FI68 BEFORE HE CALLS -C W3NOGDS. THIS WOULD MAKE THE FIRST 30 BYTES OF -C THE PDS, USER THEN WOULD MAKE BYTES AFTER 30. -C ID - INTEGER ARRAY OF VALUES THAT W3FI68 WILL USE -C TO MAKE AN EDITION 1 PDS IF IPFLAG=0. (SEE THE -C DOCBLOCK FOR W3FI68 FOR LAYOUT OF ARRAY) -C PDS - CHARACTER ARRAY OF VALUES (VALID PDS SUPPLIED -C BY USER) IF IPFLAG=1. LENGTH MAY EXCEED 28 BYTES -C (CONTENTS OF BYTES BEYOND 28 ARE PASSED -C THROUGH UNCHANGED). -C -C IGFLAG - 0 = MAKE GDS BASED ON 'IGRID' VALUE. -C 1 = MAKE GDS FROM USER SUPPLIED INFO IN 'IGDS' -C AND 'IGRID' VALUE. -C SEE REMARKS #4. -C 2 = NO GDS WILL BE INCLUDED...for international grids -C *** THIS IS AN EXCEPTION TO REMARKS #4!!!! -C IGRID - # = GRID IDENTIFICATION (TABLE B) -C 255 = IF USER DEFINED GRID; IGDS MUST BE SUPPLIED -C AND IGFLAG MUST =1. -C IGDS - INTEGER ARRAY CONTAINING USER GDS INFO (SAME -C FORMAT AS SUPPLIED BY W3FI71 - SEE DOCKBLOCK FOR -C LAYOUT) IF IGFLAG=1. -C ICOMP - RESOLUTION AND COMPONENT FLAG FOR BIT 5 OF GDS(17) -C 0 = EARTH ORIENTED WINDS -C 1 = GRID ORIENTED WINDS -C -C IBFLAG - 0 = MAKE BIT MAP FROM USER SUPPLIED DATA -C # = BIT MAP PREDEFINED BY CENTER -C SEE REMARKS #5. -C IBMAP - INTEGER ARRAY CONTAINING BIT MAP -C IBLEN - LENGTH OF BIT MAP WILL BE USED TO VERIFY LENGTH -C OF FIELD (ERROR IF IT DOESN'T MATCH). -C -C IBDSFL - INTEGER ARRAY CONTAINING TABLE 11 FLAG INFO -C BDS OCTET 4: -C (1) 0 = GRID POINT DATA -C 1 = SPHERICAL HARMONIC COEFFICIENTS -C (2) 0 = SIMPLE PACKING -C 1 = SECOND ORDER PACKING -C (3) ... SAME VALUE AS 'ITYPE' -C 0 = ORIGINAL DATA WERE FLOATING POINT VALUES -C 1 = ORIGINAL DATA WERE INTEGER VALUES -C (4) 0 = NO ADDITIONAL FLAGS AT OCTET 14 -C 1 = OCTET 14 CONTAINS FLAG BITS 5-12 -C (5) 0 = RESERVED - ALWAYS SET TO 0 -C BYTE 6 OPTION 1 NOT AVAILABLE (AS OF 5-16-93) -C (6) 0 = SINGLE DATUM AT EACH GRID POINT -C 1 = MATRIX OF VALUES AT EACH GRID POINT -C BYTE 7 OPTION 0 WITH SECOND ORDER PACKING N/A (AS OF 5-16-93) -C (7) 0 = NO SECONDARY BIT MAPS -C 1 = SECONDARY BIT MAPS PRESENT -C (8) 0 = SECOND ORDER VALUES HAVE CONSTANT WIDTH -C 1 = SECOND ORDER VALUES HAVE DIFFERENT WIDTHS -C -C OUTPUT ARGUMENT LIST: -C NPTS - NUMBER OF GRIDPOINTS IN ARRAY FLD OR IFLD -C KBUF - ENTIRE GRIB MESSAGE ('GRIB' TO '7777') -C EQUIVALENCE TO INTEGER ARRAY TO MAKE SURE IT -C IS ON WORD BOUNARY. -C ITOT - TOTAL LENGTH OF GRIB MESSAGE IN BYTES -C JERR - = 0, COMPLETED MAKING GRIB FIELD WITHOUT ERROR -C 1, IPFLAG NOT 0 OR 1 -C 2, IGFLAG NOT 0 OR 1 OR 2 -C 3, ERROR CONVERTING IEEE F.P. NUMBER TO IBM370 F.P. -C 4, W3FI71 ERROR/IGRID NOT DEFINED -C 5, W3FK74 ERROR/GRID REPRESENTATION TYPE NOT VALID -C 6, GRID TOO LARGE FOR PACKER DIMENSION ARRAYS -C SEE AUTOMATION DIVISION FOR REVISION! -C 7, LENGTH OF BIT MAP NOT EQUAL TO SIZE OF FLD/IFLD -C 8, W3FI73 ERROR, ALL VALUES IN IBMAP ARE ZERO -C -C OUTPUT FILES: -C FT06F001 - STANDARD FORTRAN OUTPUT PRINT FILE -C -C SUBPROGRAMS CALLED: -C LIBRARY: -C W3LIB - W3FI58, W3FI59, W3FI68, W3FI71, W3FI73, W3FI74 -C W3FI75, W3FI76, W3FI01 -C -C REMARKS: -C 1) IF BIT MAP TO BE INCLUDED IN MESSAGE, NULL DATA SHOULD -C BE INCLUDED IN FLD OR IFLD. THIS ROUTINE WILL TAKE CARE -C OF 'DISCARDING' ANY NULL DATA BASED ON THE BIT MAP. -C 2) UNITS MUST BE THOSE IN GRIB DOCUMENTATION: NMC O.N. 388 -C OR WMO PUBLICATION 306. -C 3) IN EITHER CASE, INPUT NUMBERS WILL BE MULTIPLIED BY -C '10 TO THE NTH' POWER FOUND IN ID(25) OR PDS(27-28), -C THE D-SCALING FACTOR, PRIOR TO BINARY PACKING. -C 4) ALL NMC PRODUCED GRIB FIELDS WILL HAVE A GRID DEFINITION -C SECTION INCLUDED IN THE GRIB MESSAGE. ID(6) WILL BE -C SET TO '1'. -C - GDS WILL BE BUILT BASED ON GRID NUMBER (IGRID), UNLESS -C IGFLAG=1 (USER SUPPLYING IGDS). USER MUST STILL SUPPLY -C IGRID EVEN IF IGDS PROVIDED. -C 5) IF BIT MAP USED THEN ID(7) OR PDS(8) MUST INDICATE THE -C PRESENCE OF A BIT MAP. -C 6) ARRAY KBUF SHOULD BE EQUIVALENCED TO AN INTEGER VALUE OR -C ARRAY TO MAKE SURE IT IS ON A WORD BOUNDARY. -C 7) SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY C916/256, Y-MP8/864, Y-MP EL92/256, J916/2048 -C -C$$$ -C - PARAMETER (MXSIZE=260000) -C ALLOW UP TO 24 BITS PER POINT - PARAMETER (MXSIZ3=MXSIZE*3) - PARAMETER (MXSIZB=MXSIZE/8+6) -C FOR 64 BIT CRAY - PARAMETER (MXSIZI=MXSIZ3/8) -C FOR 32 BIT WORKSTATIONS AND HDS -C PARAMETER (MXSIZI=MXSIZ3/4) -C - REAL FLD(*) -C - INTEGER IBDSFL(*) - INTEGER IBMAP(*) - INTEGER ID(*) - INTEGER IFLD(*) - INTEGER IGDS(*) - INTEGER IPFLD(MXSIZI) - INTEGER IB(4) -C - CHARACTER * 1 BDS11(11) - CHARACTER * 1 KBUF(*) - CHARACTER * 1 PDS(*) - CHARACTER * 1 GDS(200) - CHARACTER * 1 BMS(MXSIZB) - CHARACTER * 1 PFLD(MXSIZ3) - CHARACTER * 1 SEVEN - CHARACTER * 1 ZERO -C - EQUIVALENCE (IPFLD(1),PFLD(1)) - EQUIVALENCE (BDS11(1),IDUMMY) -C -C ASCII REP OF /'G', 'R', 'I', 'B'/ -C - DATA IB / 71, 82, 73, 66/ -C - IER = 0 - IBERR = 0 - JERR = 0 - IGRIBL = 8 - IPDSL = 0 - LENGDS = 0 - LENBMS = 0 - LENBDS = 0 - ITOSS = 0 -C -C 1.0 PRODUCT DEFINITION SECTION(PDS). -C -C SET ID(6) TO 1 ...OR... MODIFY PDS(8) ... -C REGARDLESS OF USER SPECIFICATION... -C NMC GRIB FIELDS WILL ALWAYS HAVE A GDS -C ***** exception for international GRIB GRIDS 21-26, 61-64 -C ***** which will NOT contain a GDS until subroutine W3FI71 is fixed! -C - IF (IPFLAG .EQ.0) THEN - ID(6) = 1 - if (igflag .eq. 2) then - id(6) = 0 - endif - CALL W3FI68(ID,PDS) - ELSE IF (IPFLAG .EQ. 1) THEN - IF (IAND(mova2i(PDS(8)),64) .EQ. 64) THEN -C BOTH GDS AND BMS - PDS(8) = CHAR(192) - ELSE IF (mova2i(PDS(8)) .EQ. 0) THEN -C GDS ONLY - PDS(8) = CHAR(128) - END IF - CONTINUE - ELSE -C PRINT *,' W3NOGDS ERROR, IPFLAG IS NOT 0 OR 1 IPFLAG = ',IPFLAG - JERR = 1 - GO TO 900 - END IF -C -C GET LENGTH OF PDS -C - IPDSL = mova2i(PDS(1)) * 65536 + mova2i(PDS(2)) * 256 + - & mova2i(PDS(3)) -C -C 2.0 GRID DEFINITION SECTION (GDS). -C -C IF IGFLAG=1 THEN USER IS SUPPLYING THE IGDS INFORMATION -C IF IGFLAG=2 THEN USER doesn't want a GDS and this section -C will be skipped...LENGDS=0 -C - IF (IGFLAG .EQ. 0) THEN - CALL W3FI71(IGRID,IGDS,IGERR) - IF (IGERR .EQ. 1) THEN -C PRINT *,' W3FI71 ERROR, GRID TYPE NOT DEFINED...',IGRID - JERR = 4 - GO TO 900 - END IF - END IF - IF (IGFLAG .EQ. 0 .OR. IGFLAG .EQ.1) THEN - CALL W3FI74(IGDS,ICOMP,GDS,LENGDS,NPTS,IGERR) - IF (IGERR .EQ. 1) THEN -C PRINT *,' W3FI74 ERROR, GRID REP TYPE NOT VALID...',IGDS(3) - JERR = 5 - GO TO 900 - ELSE - END IF - IF (NPTS .GT. MXSIZE) THEN -C PRINT *,' W3NOGDS ERROR, GRID TOO LARGE FOR PACKER ARRAY', -C & ' DIMENSIONS' - JERR = 6 - GO TO 900 - END IF - else if (igflag .eq. 2) then - lengds = 0 - if (igrid.eq.21) then - npts=1333 - else if (igrid.eq.22) then - npts=1333 - else if (igrid.eq.23) then - npts=1333 - else if (igrid.eq.24) then - npts=1333 - else if (igrid.eq.25) then - npts=1297 - else if (igrid.eq.26) then - npts=1297 - else if ((igrid.ge.61).and.(igrid.le.64)) then - npts=4096 - end if - ELSE -C PRINT *,' W3NOGDS ERROR, IGFLAG IS NOT 0-2 IGFLAG = ',IGFLAG - GO TO 900 - END IF -C -C 3.0 BIT MAP SECTION (BMS). -C -C SET ITOSS=1 IF BITMAP BEING USED. W3FI75 WILL TOSS DATA -C PRIOR TO PACKING. LATER CODING WILL BE NEEDED WHEN THE -C 'PREDEFINED' GRIDS ARE FINALLY 'DEFINED'. -C - IF (mova2i(PDS(8)) .EQ. 64 .OR. - & mova2i(PDS(8)) .EQ. 192) THEN - ITOSS = 1 - IF (IBFLAG .EQ. 0) THEN - IF (IBLEN .NE. NPTS) THEN -C PRINT *,' W3NOGDS ERROR, IBLEN .NE. NPTS = ',IBLEN,NPTS - JERR = 7 - GO TO 900 - END IF - CALL W3FI73(IBFLAG,IBMAP,IBLEN,BMS,LENBMS,IER) - IF (IER .NE. 0) THEN -C PRINT *,' W3FI73 ERROR, IBMAP VALUES ARE ALL ZERO' - JERR = 8 - GO TO 900 - END IF - ELSE -C PRINT *,' BIT MAP PREDEFINED BY CENTER, IBFLAG = ',IBFLAG - END IF - END IF -C -C 4.0 BINARY DATA SECTION (BDS). -C -C 4.1 SCALE THE DATA WITH D-SCALE FROM PDS(27-28) -C - JSCALE = mova2i(PDS(27)) * 256 + mova2i(PDS(28)) - IF (IAND(JSCALE,32768).NE.0) THEN - JSCALE = - IAND(JSCALE,32767) - END IF - SCALE = 10.0 ** JSCALE - IF (ITYPE .EQ. 0) THEN - DO 410 I = 1,NPTS - FLD(I) = FLD(I) * SCALE - 410 CONTINUE - ELSE - DO 411 I = 1,NPTS - IFLD(I) = NINT(FLOAT(IFLD(I)) * SCALE) - 411 CONTINUE - END IF -C -C 4.2 CALL W3FI75 TO PACK DATA AND MAKE BDS. -C - CALL W3FI75(IBITL,ITYPE,ITOSS,FLD,IFLD,IBMAP,IBDSFL, - & NPTS,BDS11,IPFLD,PFLD,LEN,LENBDS,IBERR,PDS,IGDS) - IF (IBERR .EQ. 1) THEN - JERR = 3 - GO TO 900 - END IF -C 4.3 IF D-SCALE NOT 0, RESCALE INPUT FIELD TO -C ORIGINAL VALUE -C - IF (JSCALE.NE.0) THEN - DSCALE = 1.0 / SCALE - IF (ITYPE.EQ.0) THEN - DO 412 I = 1, NPTS - FLD(I) = FLD(I) * DSCALE - 412 CONTINUE - ELSE - DO 413 I = 1, NPTS - FLD(I) = NINT(FLOAT(IFLD(I)) * DSCALE) - 413 CONTINUE - END IF - END IF -C -C 5.0 OUTPUT SECTION. -C -C 5.1 ZERO OUT THE OUTPUT ARRAY KBUF. -C - ZERO = CHAR(00) - ITOT = IGRIBL + IPDSL + LENGDS + LENBMS + LENBDS + 4 -C PRINT *,'IGRIBL =',IGRIBL -C PRINT *,'IPDSL =',IPDSL -C PRINT *,'LENGDS =',LENGDS -C PRINT *,'LENBMS =',LENBMS -C PRINT *,'LENBDS =',LENBDS -C PRINT *,'ITOT =',ITOT -C -C KBUF MUST BE ON A WORD BOUNDRY, EQUIVALENCE TO AN -C INTEGER ARRAY IN THE MAIN PROGRAM TO MAKE SURE IT IS. -C THIS IS BOTH COMPUTER AND COMPILER DEPENDENT, W3FI01 -C IS USED TO FILL OUT IF THE COMPUTER IS A 64 BIT OR -C 32 BIT WORD SIZE COMPUTER. LW IS SET TO 4 FOR 32 BIT -C COMPUTER, 8 FOR 64 BIT COMPUTER. -C - CALL W3FI01(LW) - IWORDS = ITOT / LW - CALL XSTORE(KBUF,0,IWORDS) - IF (MOD(ITOT,LW).NE.0) THEN - IBYTES = ITOT - IWORDS * LW - DO 510 I = 1,IBYTES - KBUF(IWORDS * LW + I) = ZERO - 510 CONTINUE - END IF -C -C 5.2 MOVE SECTION 0 - 'IS' INTO KBUF (8 BYTES). -C - ISTART = 0 - DO 520 I = 1,4 - KBUF(I) = CHAR(IB(I)) - 520 CONTINUE -C - KBUF(5) = CHAR(MOD(ITOT / 65536,256)) - KBUF(6) = CHAR(MOD(ITOT / 256,256)) - KBUF(7) = CHAR(MOD(ITOT ,256)) - KBUF(8) = CHAR(1) -C -C 5.3 MOVE SECTION 1 - 'PDS' INTO KBUF (28 BYTES). -C - ISTART = ISTART + IGRIBL - IF (IPDSL.GT.0) THEN - CALL XMOVEX(KBUF(ISTART+1),PDS,IPDSL) - ELSE -C PRINT *,'LENGTH OF PDS LESS OR EQUAL 0, IPDSL = ',IPDSL - END IF -C -C 5.4 MOVE SECTION 2 - 'GDS' INTO KBUF. -C - ISTART = ISTART + IPDSL - IF (LENGDS .GT. 0) THEN - CALL XMOVEX(KBUF(ISTART+1),GDS,LENGDS) - END IF -C -C 5.5 MOVE SECTION 3 - 'BMS' INTO KBUF. -C - ISTART = ISTART + LENGDS - IF (LENBMS .GT. 0) THEN - CALL XMOVEX(KBUF(ISTART+1),BMS,LENBMS) - END IF -C -C 5.6 MOVE SECTION 4 - 'BDS' INTO KBUF. -C -C MOVE THE FIRST 11 OCTETS OF THE BDS INTO KBUF. -C - ISTART = ISTART + LENBMS - CALL XMOVEX(KBUF(ISTART+1),BDS11,11) -C -C MOVE THE PACKED DATA INTO THE KBUF -C - ISTART = ISTART + 11 - IF (LEN.GT.0) THEN - CALL XMOVEX(KBUF(ISTART+1),PFLD,LEN) - END IF -C -C ADD '7777' TO END OFF KBUF -C NOTE THAT THESE 4 OCTETS NOT INCLUDED IN ACTUAL SIZE OF BDS. -C - SEVEN = CHAR(55) - ISTART = ITOT - 4 - DO 562 I = 1,4 - KBUF(ISTART+I) = SEVEN - 562 CONTINUE -C - 900 CONTINUE - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3pradat.f b/external/w3nco/v2.0.6/src/w3pradat.f deleted file mode 100644 index d89c1e18b..000000000 --- a/external/w3nco/v2.0.6/src/w3pradat.f +++ /dev/null @@ -1,78 +0,0 @@ -!----------------------------------------------------------------------- - subroutine w3pradat(idat,cdat) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3PRADAT FORMAT A DATE AND TIME INTO CHARACTERS -! AUTHOR: MARK IREDELL ORG: WP23 DATE: 98-01-05 -! -! ABSTRACT: THIS SUBPROGRAM FORMS VARIOUS CHARACTER STRINGS USEFUL -! IN DESCRIBING AN NCEP ABSOLUTE DATE AND TIME. -! -! PROGRAM HISTORY LOG: -! 98-01-05 MARK IREDELL -! -! USAGE: CALL W3PRADAT(IDAT,CDAT) -! -! INPUT VARIABLES: -! IDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! -! OUTPUT VARIABLES: -! CDAT CHARACTER*10 (8) STRINGS DESCRIBING DATE AND TIME -! (CDAT(1) IS THE NAME OF THE DAY OF THE WEEK; -! CDAT(2) IS THE NAME OF THE MONTH; -! CDAT(3) IS THE DAY OF MONTH, YEAR; -! CDAT(4) IS THE DATE IN YYYY-MM-DD FORMAT; -! CDAT(5) IS THE DATE IN YYYY.DOY FORMAT; -! CDAT(6) IS THE TIME IN HH:MM:SS FORMAT; -! CDAT(7) IS THE MILLISECONDS IN .XXX FORMAT; -! CDAT(8) IS THE TIME ZONE.) -! -! SUBPROGRAMS CALLED: -! IW3JDN COMPUTE JULIAN DAY NUMBER -! W3FS26 YEAR, MONTH, DAY FROM JULIAN DAY NUMBER -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - integer idat(8) - character*(*) cdat(8) - character*10 ctmp(8) - character*10 cmon(12) - data cmon/'January ','February ','March ', - & 'April ','May ','June ', - & 'July ','August ','September ', - & 'October ','November ','December '/ - character*10 cdow(7) - data cdow/'Sunday ','Monday ','Tuesday ', - & 'Wednesday ','Thursday ','Friday ', - & 'Saturday '/ -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! get day of week and day of year, convert day of week and month -! to english names, write other formats of date and time, and -! write time zone differential in one of three ways. - jldayn=iw3jdn(idat(1),idat(2),idat(3)) - call w3fs26(jldayn,jy,jm,jd,jdow,jdoy) - ctmp(1)=cdow(jdow) - ctmp(2)='********' - if(idat(2).ge.1.and.idat(2).le.12) ctmp(2)=cmon(idat(2)) - write(ctmp(3),'(i2,", ",i4)') idat(3),idat(1) - write(ctmp(4),'(i4,"-",i2.2,"-",i2.2)') idat(1),idat(2),idat(3) - write(ctmp(5),'(i4,".",i3.3)') idat(1),jdoy - write(ctmp(6),'(i2.2,":",i2.2,":",i2.2)') idat(5),idat(6),idat(7) - write(ctmp(7),'(".",i3.3)') idat(8) - if(idat(4).eq.0) then - write(ctmp(8),'("UTC")') - elseif(mod(idat(4),100).eq.0) then - kh=idat(4)/100 - write(ctmp(8),'("UTC",sp,i3.2,"h")') kh - else - kh=idat(4)/100 - km=abs(mod(idat(4),100)) - write(ctmp(8),'("UTC",sp,i3.2,"h",ss,i2.2,"m")') kh,km - endif - cdat=ctmp -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end diff --git a/external/w3nco/v2.0.6/src/w3reddat.f b/external/w3nco/v2.0.6/src/w3reddat.f deleted file mode 100644 index d15d52933..000000000 --- a/external/w3nco/v2.0.6/src/w3reddat.f +++ /dev/null @@ -1,142 +0,0 @@ - subroutine w3reddat(it,rinc,dinc) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3REDDAT REDUCE A TIME INTERVAL TO A CANONICAL FORM -! AUTHOR: MARK IREDELL ORG: WP23 DATE: 98-01-05 -! -! ABSTRACT: THIS SUBPROGRAM REDUCES AN NCEP RELATIVE TIME INTERVAL -! INTO ONE OF SEVEN CANONICAL FORMS, DEPENDING ON THE INPUT IT VALUE. -! -! First reduced format type (IT=-1): -! RINC(1) is an arbitrary integer. -! RINC(2) is an integer between 00 and 23, inclusive. -! RINC(3) is an integer between 00 and 59, inclusive. -! RINC(4) is an integer between 00 and 59, inclusive. -! RINC(5) is an integer between 000 and 999, inclusive. -! If RINC(1) is negative, then the time interval is negative. -! -! Second reduced format type (IT=0): -! If the time interval is not negative, then the format is: -! RINC(1) is zero or a positive integer. -! RINC(2) is an integer between 00 and 23, inclusive. -! RINC(3) is an integer between 00 and 59, inclusive. -! RINC(4) is an integer between 00 and 59, inclusive. -! RINC(5) is an integer between 000 and 999, inclusive. -! Otherwise if the time interval is negative, then the format is: -! RINC(1) is zero or a negative integer. -! RINC(2) is an integer between 00 and -23, inclusive. -! RINC(3) is an integer between 00 and -59, inclusive. -! RINC(4) is an integer between 00 and -59, inclusive. -! RINC(5) is an integer between 000 and -999, inclusive. -! -! Days format type (IT=1): -! RINC(1) is arbitrary. -! RINC(2) is zero. -! RINC(3) is zero. -! RINC(4) is zero. -! RINC(5) is zero. -! -! Hours format type (IT=2): -! RINC(1) is zero. -! RINC(2) is arbitrary. -! RINC(3) is zero. -! RINC(4) is zero. -! RINC(5) is zero. -! (This format should not express time intervals longer than 300 years.) -! -! Minutes format type (IT=3): -! RINC(1) is zero. -! RINC(2) is zero. -! RINC(3) is arbitrary. -! RINC(4) is zero. -! RINC(5) is zero. -! (This format should not express time intervals longer than five years.) -! -! Seconds format type (IT=4): -! RINC(1) is zero. -! RINC(2) is zero. -! RINC(3) is zero. -! RINC(4) is arbitrary. -! RINC(5) is zero. -! (This format should not express time intervals longer than one month.) -! -! Milliseconds format type (IT=5): -! RINC(1) is zero. -! RINC(2) is zero. -! RINC(3) is zero. -! RINC(4) is zero. -! RINC(5) is arbitrary. -! (This format should not express time intervals longer than one hour.) -! -! PROGRAM HISTORY LOG: -! 98-01-05 MARK IREDELL -! -! USAGE: CALL W3REDDAT(IT,RINC,DINC) -! -! INPUT VARIABLES: -! IT INTEGER RELATIVE TIME INTERVAL FORMAT TYPE -! (-1 FOR FIRST REDUCED TYPE (HOURS ALWAYS POSITIVE), -! 0 FOR SECOND REDUCED TYPE (HOURS CAN BE NEGATIVE), -! 1 FOR DAYS ONLY, 2 FOR HOURS ONLY, 3 FOR MINUTES ONLY, -! 4 FOR SECONDS ONLY, 5 FOR MILLISECONDS ONLY) -! RINC REAL (5) NCEP RELATIVE TIME INTERVAL -! (DAYS, HOURS, MINUTES, SECONDS, MILLISECONDS) -! -! OUTPUT VARIABLES: -! DINC REAL (5) NCEP RELATIVE TIME INTERVAL -! (DAYS, HOURS, MINUTES, SECONDS, MILLISECONDS) -! -! SUBPROGRAMS CALLED: -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - real rinc(5),dinc(5) -! parameters for number of units in a day -! and number of milliseconds in a unit -! and number of next smaller units in a unit, respectively - integer,dimension(5),parameter:: itd=(/1,24,1440,86400,86400000/), - & itm=itd(5)/itd - integer,dimension(4),parameter:: itn=itd(2:5)/itd(1:4) - integer,parameter:: np=16 - integer iinc(4),jinc(5),kinc(5) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! first reduce to the first reduced form - iinc=floor(rinc(1:4)) -! convert all positive fractional parts to milliseconds -! and determine canonical milliseconds - jinc(5)=nint(dot_product(rinc(1:4)-iinc,real(itm(1:4)))+rinc(5)) - kinc(5)=modulo(jinc(5),itn(4)) -! convert remainder to seconds and determine canonical seconds - jinc(4)=iinc(4)+(jinc(5)-kinc(5))/itn(4) - kinc(4)=modulo(jinc(4),itn(3)) -! convert remainder to minutes and determine canonical minutes - jinc(3)=iinc(3)+(jinc(4)-kinc(4))/itn(3) - kinc(3)=modulo(jinc(3),itn(2)) -! convert remainder to hours and determine canonical hours - jinc(2)=iinc(2)+(jinc(3)-kinc(3))/itn(2) - kinc(2)=modulo(jinc(2),itn(1)) -! convert remainder to days and compute milliseconds of the day - kinc(1)=iinc(1)+(jinc(2)-kinc(2))/itn(1) - ms=dot_product(kinc(2:5),itm(2:5)) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! next reduce to either single value canonical form -! or to one of the two reduced forms - if(it.ge.1.and.it.le.5) then -! ensure that exact multiples of 1./np are expressed exactly -! (other fractions may have precision errors) - rp=(np*ms)/itm(it)+mod(np*ms,itm(it))/real(itm(it)) - dinc=0 - dinc(it)=real(kinc(1))*itd(it)+rp/np - else -! the reduced form is done except the second reduced form is modified -! for negative time intervals with fractional days - dinc=kinc - if(it.eq.0.and.kinc(1).lt.0.and.ms.gt.0) then - dinc(1)=dinc(1)+1 - dinc(2:5)=mod(ms-itm(1),itm(1:4))/itm(2:5) - endif - endif -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end diff --git a/external/w3nco/v2.0.6/src/w3tagb.f b/external/w3nco/v2.0.6/src/w3tagb.f deleted file mode 100644 index 8b4deef66..000000000 --- a/external/w3nco/v2.0.6/src/w3tagb.f +++ /dev/null @@ -1,121 +0,0 @@ - SUBROUTINE W3TAGB(PROG,KYR,JD,LF,ORG) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: W3TAGB OPERATIONAL JOB IDENTIFIER -C PRGMMR: FARLEY ORG: NP11 DATE: 1998-03-17 -C -C ABSTRACT: PRINTS IDENTIFYING INFORMATION FOR OPERATIONAL -C codes. CALLED AT THE BEGINNING OF A code, W3TAGB PRINTS -C THE program NAME, THE YEAR AND JULIAN DAY OF ITS -C COMPILATION, AND THE RESPONSIBLE ORGANIZATION. ON A 2ND -C LINE IT PRINTS THE STARTING DATE-TIME. CALLED AT THE -C END OF A JOB, entry routine, W3TAGE PRINTS A LINE WITH THE -C ENDING DATE-TIME AND A 2ND LINE STATING THE program name -C AND THAT IT HAS ENDED. -C -C PROGRAM HISTORY LOG: -C 85-10-29 J.NEWELL -C 89-10-20 R.E.JONES CONVERT TO CRAY CFT77 FORTRAN -C 91-03-01 R.E.JONES ADD MACHINE NAME TO ENDING LINE -C 92-12-02 R.E.JONES ADD START-ENDING TIME-DATE -C 93-11-16 R.E.JONES ADD DAY OF YEAR, DAY OF WEEK, AND JULIAN DAY -C NUMBER. -C 97-12-24 M.FARLEY PRINT STATEMENTS MODIFIED FOR 4-DIGIT YR -C 98-03-17 M.FARLEY REPLACED DATIMX WITH CALLS TO W3LOCDAT/W3DOXDAT -C 99-01-29 B. VUONG CONVERTED TO IBM RS/6000 SP -C -C 99-06-17 A. Spruill ADJUSTED THE SIZE OF PROGRAM NAME TO ACCOMMODATE -C THE 20 CHARACTER NAME CONVENTION ON THE IBM SP. -C 1999-08-24 Gilbert added call to START() in W3TAGB and a call -C to SUMMARY() in W3TAGE to print out a -C resource summary list for the program using -C W3TAGs. -C 2012-10-18 Vuong REMOVE PRINT STATEMENT 604 -C 2013-02-06 Vuong MODIFIED PRINT STATEMENT 604 -C -C USAGE: CALL W3TAGB(PROG, KYR, JD, LF, ORG) -C CALL W3TAGE(PROG) -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C PROG ARG LIST PROGRAM NAME CHARACTER*1 -C KYR ARG LIST YEAR OF COMPILATION INTEGER -C JD ARG LIST JULIAN DAY OF COMPILATION INTEGER -C LF ARG LIST HUNDRETHS OF JULIAN DAY OF COMPILATION -C INTEGER (RANGE IS 0 TO 99 INCLUSIVE) -C ORG ARG LIST ORGANIZATION CODE (SUCH AS WD42) -C CHARACTER*1 -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ---------------------------------------------------------------- -C DDATE PRINT YEAR AND JULIAN DAY (NEAREST HUNDRETH) -C FILE OF COMPILATION REAL -C -C SUBPROGRAMS CALLED: CLOCK, DATE -C -C REMARKS: FULL WORD USED IN ORDER TO HAVE AT LEAST -C SEVEN DECIMAL DIGITS ACCURACY FOR VALUE OF DDATE. -C SUBPROGRAM CLOCK AND DATE MAY DIFFER FOR EACH TYPE -C COMPUTER. YOU MAY HAVE TO CHANGE THEM FOR ANOTHER -C TYPE OF COMPUTER. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C -C$$$ -C - CHARACTER *(*) PROG,ORG - CHARACTER * 3 JMON(12) - CHARACTER * 3 DAYW(7) -C - INTEGER IDAT(8), JDOW, JDOY, JDAY -C - SAVE -C - DATA DAYW/'SUN','MON','TUE','WEN','THU','FRI','SAT'/ - DATA JMON /'JAN','FEB','MAR','APR','MAY','JUN', - & 'JUL','AUG','SEP','OCT','NOV','DEC'/ -C - CALL START() - - DYR = KYR - DYR = 1.0E+03 * DYR - DJD = JD - DLF = LF - DLF = 1.0E-02 * DLF - DDATE = DYR + DJD + DLF - PRINT 600 - 600 FORMAT(//,10('* . * . ')) - PRINT 601, PROG, DDATE, ORG - 601 FORMAT(5X,'PROGRAM ',A,' HAS BEGUN. COMPILED ',F10.2, - & 5X, 'ORG: ',A) -C - CALL W3LOCDAT(IDAT) - CALL W3DOXDAT(IDAT,JDOW,JDOY,JDAY) - PRINT 602, JMON(IDAT(2)),IDAT(3),IDAT(1),IDAT(5),IDAT(6), - & IDAT(7),IDAT(8),JDOY,DAYW(JDOW),JDAY - 602 FORMAT(5X,'STARTING DATE-TIME ',A3,1X,I2.2,',', - & I4.4,2X,2(I2.2,':'),I2.2,'.',I3.3,2X,I3,2X,A3,2X,I8,//) - RETURN -C - ENTRY W3TAGE(PROG) -C - CALL W3LOCDAT(IDAT) - CALL W3DOXDAT(IDAT,JDOW,JDOY,JDAY) - PRINT 603, JMON(IDAT(2)),IDAT(3),IDAT(1),IDAT(5),IDAT(6), - & IDAT(7),IDAT(8),JDOY,DAYW(JDOW),JDAY - 603 FORMAT(//,5X,'ENDING DATE-TIME ',A3,1X,I2.2,',', - & I4.4,2X,2(I2.2,':'),I2.2,'.',I3.3,2X,I3,2X,A3,2X,I8) - PRINT 604, PROG - 604 FORMAT(5X,'PROGRAM ',A,' HAS ENDED.') -C 604 FORMAT(5X,'PROGRAM ',A,' HAS ENDED. CRAY J916/2048') -C 604 FORMAT(5X,'PROGRAM ',A,' HAS ENDED. CRAY Y-MP EL2/256') - PRINT 605 - 605 FORMAT(10('* . * . ')) - - CALL SUMMARY() -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3trnarg.f b/external/w3nco/v2.0.6/src/w3trnarg.f deleted file mode 100644 index 7a97df55b..000000000 --- a/external/w3nco/v2.0.6/src/w3trnarg.f +++ /dev/null @@ -1,172 +0,0 @@ - SUBROUTINE W3TRNARG(SUBDIR,LSUBDR,TANKID,LTNKID,APPCHR,LAPCHR, - 1 TLFLAG,IYMDHB,IYMDHE,IERR) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3TRNARG TRANSLATES ARG LINE FROM STANDARD INPUT -C PRGMMR: KEYSER ORG: NP22 DATE: 2002-02-11 -C -C ABSTRACT: READS ARGUMENT LINES FROM STANDARD INPUT AND OBTAINS , -C SUBDIRECTORY, BUFR TANKNAME, CHARACTERS TO APPEND FOR ADDING -C AN ORBIT, AND OPTIONS FOR LIMITING THE TIME WINDOW. -C -C PROGRAM HISTORY LOG: -C 1996-09-03 B. KATZ -- ORIGINAL AUTHOR -C 1998-11-27 B. KATZ -- CHANGES FOR Y2K AND FORTRAN 90 COMPLIANCE -C 2002-02-11 D. KEYSER -- IF "TLFLAG" IS NOT SPECIFIED, IT DEFAULTS -C TO "NOTIMLIM" RATHER THAN "TIMLIM" AND -C GROSS TIME LIMITS WILL NOT BE CALCULATED -C AND RETURNED IN "IYMDHB" AND "IYMDHE" -C -C USAGE: CALL W3TRNARG(SUBDIR,LSUBDR,TANKID,LTNKID,APPCHR,LAPCHR, -C TLFLAG,IYMDHB,IYMDHE,IERR) -C OUTPUT ARGUMENT LIST: -C SUBDIR - NAME OF SUB-DIRECTORY INCLUDING BUFR DATA TYPE WHERE -C BUFR DATA TANK IS LOCATED. -C LSUBDR - NUMBER OF CHARACTERS IN 'SUBDIR'. -C TANKID - NAME OF FILE INCLUDING BUFR DATA SUB-TYPE CONTAINING -C BUFR DATA TANK. -C LTNKID - NUMBER OF CHARACTERS IN 'TANKID'. -C APPCHR - CHARACTERS TO BE APPENDED TO 'TANKID' GIVING A -C UNIQUELY NAMED FILE TO CONTAIN THE ORIGINAL TANK -C WITH ONE ORBIT APPENDED TO IT. -C LAPCHR - NUMBER OF CHARACTERS IN 'APPCHR'. -C TLFLAG - 8 CHARACTER FLAG INDICATING WHETHER TIME ACCEPTANCE -C CHECKS ATRE TO BE PERFORMED. -C = 'TIMLIM ' : PERFORM TIME ACCEPTANCE CHECKS. -C = 'NOTIMLIM' : DO NOT PERFORM TIME ACCEPTANCE CHECKS. -C JDATE AND KDATE ARE DISREGARDED. -C IYMDHB - START OF TIME ACCEPTANCE WINDOW, IN FORM YYYYMMDDHH. -C IYMDHE - END OF TIME ACCEPTANCE WINDOW, IN FORM YYYYMMDDHH. -C -C INPUT FILES : -C UNIT 05 - STANDARD INPUT FOR PASSING IN ARGUMENTS. ARGUMENTS -C (FOR LIST-DIRECTED I/O) ARE AS FOLLOWS : -C RECORD 1 - (1) SUBDIRECTORY. CONTAINS BUFR DATA TYPE -C (2) TANKFILE. CONTAINS BUFR DATA SUB-TYPE -C (3) APPEND CHARACTERS. APPENDED TO TANKFILE -C TO GIVE UNIQUE OUTPUT FILE NAME. -C (4) DATE IN YYYYMMDDHH FORMAT. -C NEXT THREE RECORDS ARE OPTIONAL : -C RECORD 2 - (1) TIME LIMIT FLAG. MAY BE EITHER -C 'TIMLIM ' OR 'NOTIMLIM'. SEE -C DESCRIPTION OF 'TLFLAG' ABOVE. -C (DEFAULT IS 'NOTIMLIM') -C RECORD 3 - (1) HOURS BEFORE CURRENT TIME. -C RECORD 4 - (1) HOURS AFTER CURRENT TIME. -C IF 'TIMLIM ' IS SPECIFIED IN RECORD 2, THE -C QUANTITIES IN RECORDS 3 AND 4 ARE USED TO -C COMPUTE THE LIMITS OF THE TIME ACCEPTANCE WINDOW. -C IF RECORDS 3 AND 4 ARE OMITTED, THE VALUES -C DEFAULT TO -48 (48 HOURS BEFORE CURRENT TIME) -C AND +12 (12 HOURS AFTER CURRENT TIME). -C IF 'NOTIMLIM ' IS SPECIFIED IN RECORD 2, THEN -C THESE QUANTITIES ARE NOT USED REGARDLESS OF WHETHER -C OR NOT THEY WERE SPECIFIED. -C -C SUBPROGRAMS CALLED : -C W3LIB - W3MOVDAT -C -C REMARKS: -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP -C -C$$$ - CHARACTER*(*) SUBDIR,TANKID,APPCHR,TLFLAG - INTEGER IDATIN(8),IDTOUT(8) - REAL TIMINC(5) - READ(5,*,END=9999) SUBDIR,TANKID,APPCHR,IYMDH - MSUBDR = LEN(SUBDIR) - DO LSUBDR=0,MSUBDR-1 - IF(SUBDIR(LSUBDR+1:LSUBDR+1).EQ.' ') GO TO 10 - ENDDO - LSUBDR = MSUBDR - 10 CONTINUE - IF(LSUBDR.LT.4) THEN - WRITE(6,'(1X,I2,'' CHARACTERS IN SUBDIRECTORY ARGUMENT'', - 1 '' AT LEAST 4 CHARACTERS ARE REQUIRED'')') LSUBDR - IERR = 2 - RETURN - ENDIF - MTNKID = LEN(TANKID) - DO LTNKID=0,MTNKID-1 - IF(TANKID(LTNKID+1:LTNKID+1).EQ.' ') GO TO 20 - ENDDO - LTNKID = MTNKID - 20 CONTINUE - IF(LTNKID.LT.4) THEN - WRITE(6,'(1X,I2,'' CHARACTERS IN TANKFILE ARGUMENT'', - 1 '' AT LEAST 4 CHARACTERS ARE REQUIRED'')') LTNKID - IERR = 2 - RETURN - ENDIF - MAPCHR = LEN(APPCHR) - DO LAPCHR=0,MAPCHR-1 - IF(APPCHR(LAPCHR+1:LAPCHR+1).EQ.' ') GO TO 30 - ENDDO - LAPCHR = MAPCHR - 30 CONTINUE - TLFLAG = 'NOTIMLIM' ! The default is to NOT perform time checks - READ(5,*,END=40) TLFLAG - 40 CONTINUE - IF(TLFLAG(1:6).NE.'TIMLIM') THEN - TLFLAG = 'NOTIMLIM' - PRINT 123, IYMDH,SUBDIR(1:LSUBDR),TANKID(1:LTNKID) - 123 FORMAT(/'RUN ON ',I10/'WRITE TO ',A,'/',A/'GROSS TIME LIMIT ', - 1 'CHECKS ARE NOT PERFORMED HERE - SUBSEQUENT PROGRAM ', - 1 'BUFR_TRANJB WILL TAKE CARE OF THIS'/) - IYMDHB = 0000000000 - IYMDHE = 2100000000 - IERR = 0 - RETURN - ENDIF - TLFLAG(7:8) = ' ' - READ(5,*,END=60) IHRBEF - GO TO 70 - 60 CONTINUE - IHRBEF = -48 - IHRAFT = 12 - GO TO 100 - 70 CONTINUE - READ(5,*,END=80) IHRAFT - GO TO 90 - 80 CONTINUE - IHRAFT = 12 - GO TO 100 - 90 CONTINUE - IF(IHRBEF.GT.0 .AND. IHRAFT.LT.0) THEN - ITEMP = IHRBEF - IHRBEF = IHRAFT - IHRAFT = ITEMP - ELSE IF(IHRBEF.GT.0) THEN - IHRBEF = -1 * IHRBEF - ENDIF - 100 CONTINUE - IDATIN(1) = IYMDH / 1000000 - IDATIN(2) = MOD(IYMDH,1000000) / 10000 - IDATIN(3) = MOD(IYMDH,10000) / 100 - IDATIN(4) = 0 - IDATIN(5) = MOD(IYMDH,100) - IDATIN(6:8) = 0 - TIMINC(1) = 0.0 - TIMINC(2) = FLOAT(IHRBEF) - TIMINC(3:5) = 0.0 - CALL W3MOVDAT(TIMINC,IDATIN,IDTOUT) - IYMDHB = ((IDTOUT(1) * 100 + IDTOUT(2)) * 100 + IDTOUT(3)) * - 1 100 + IDTOUT(5) - TIMINC(2) = FLOAT(IHRAFT) - CALL W3MOVDAT(TIMINC,IDATIN,IDTOUT) - IYMDHE = ((IDTOUT(1) * 100 + IDTOUT(2)) * 100 + IDTOUT(3)) * - 1 100 + IDTOUT(5) - PRINT 124, IYMDH,SUBDIR(1:LSUBDR),TANKID(1:LTNKID),IYMDHB,IYMDHE - 124 FORMAT(/'RUN ON ',I10/'WRITE TO ',A,'/',A/'ACCEPT BETWEEN ',I10, - 1 ' AND ',I10/) - IERR = 0 - RETURN - 9999 CONTINUE - WRITE(6,'('' INSUFFICIENT NO. OF ARGUMENTS TO BUFR '', - 1 ''TRANSLATION PROCEDURE - AT LEAST 4 ARE NEEDED'')') - IERR = 1 - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3unpk77.f b/external/w3nco/v2.0.6/src/w3unpk77.f deleted file mode 100644 index e8e2669df..000000000 --- a/external/w3nco/v2.0.6/src/w3unpk77.f +++ /dev/null @@ -1,2580 +0,0 @@ -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: W3UNPK77 DECODES SINGLE REPORT FROM BUFR MESSAGES -C PRGMMR: KEYSER ORG: NP22 DATE: 2002-03-05 -C -C ABSTRACT: THIS SUBROUTINE DECODES A SINGLE REPORT FROM BUFR MESSAGES -C IN A JBUFR-TYPE DATA FILE. CURRENTLY WIND PROFILER, NEXRAD (VAD) -C WIND AND GOES SOUNDING/RADIANCE DATA TYPES ARE VALID. REPORT IS -C RETURNED IN QUASI-OFFICE NOTE 29 UNPACKED FORMAT (SEE REMARKS 4.). -C -C PROGRAM HISTORY LOG: -C 1996-12-16 KEYSER -- ORIGINAL AUTHOR (BASED ON W3LIB ROUTINE W3FI77) -C 1997-06-02 KEYSER -- ADDED NEXRAD (VAD) WIND DATA TYPE -C 1997-06-16 KEYSER -- ADDED GOES SOUNDING/RADIANCE DATA TYPE -C 1997-09-18 KEYSER -- ADDED INSTRUMENT DATA USED IN PROCESSING, -C SOLAR ZENITH ANGLE, AND SATELLITE ZENITH ANGLE -C TO LIST OF PARAMETERS RETURNED FROM GOES -C SOUNDING/RADIANCE DATA TYPE -C 1998-07-09 KEYSER -- MODIFIED WIND PROFILER CAT. 11 (HEIGHT, HORIZ. -C SIGNIFICANCE, VERT. SIGNIFICANCE) TO ACCOUNT -C FOR UPDATES TO BUFRTABLE MNEMONICS IN /dcom; -C CHANGED CHAR. 6 OF GOES STNID TO BE UNIQUE FOR -C TWO DIFFERENT EVEN OR ODD SATELLITE ID'S -C (EVERY OTHER EVEN OR ODD SAT. ID NOW GETS SAME -C CHAR. 6 TAG) -C 1998-08-19 KEYSER -- SUBROUTINE NOW Y2K AND FORTRAN 90 COMPLIANT -C 1999-03-16 KEYSER -- INCORPORATED BOB KISTLER'S CHANGES NEEDED -C TO PORT THE CODE TO THE IBM SP -C 1999-05-17 KEYSER -- MADE CHANGES NECESSARY TO PORT THIS ROUTINE TO -C THE IBM SP -C 1999-09-26 KEYSER -- CHANGES TO MAKE CODE MORE PORTABLE -C 2002-03-05 KEYSER -- ACCOUNTS FOR CHANGES IN INPUT PROFLR (WIND -C PROFILER) BUFR DUMP FILE AFTER 3/2002: CAT. 10 -C SURFACE DATA NOW ALL MISSING (MNEMONICS "PMSL", -C "WDIR1","WSPD1", "TMDB", "REHU", "REQV" NO -C LONGER AVAILABLE); CAT. 11 MNEMONICS "ACAVH", -C "ACAVV", "SPP0", AND "NPHL" NO LONGER -C AVAILABLE; HEADER MNEMONIC "NPSM" IS NO LONGER -C AVAILABLE, HEADER MNEMONIC "TPSE" REPLACES -C "TPMI" (AVG. TIME IN MINUTES STILL OUTPUT); -C NUMBER OF UPPER-AIR LEVELS INCR. FROM 43 TO UP -C TO 64 (SIZE OF OUTPUT "RDATA" ARRAY INCR. FROM -C 600 TO 1200 TO ACCOUNT FOR THIS) (WILL STILL -C WORK PROPERLY FOR INPUT PROFLR DUMP FILES PRIOR -C TO 3/2002) -C -C -C USAGE: CALL W3UNPK77(IDATE,IHE,IHL,LUNIT,RDATA,IRET) -C INPUT ARGUMENT LIST: -C IDATE - 4-WORD ARRAY HOLDING "CENTRAL" DATE TO PROCESS -C - (YYYY, MM, DD, HH) -C IHE - NUMBER OF WHOLE HOURS RELATIVE TO "IDATE" FOR DATE OF -C - EARLIEST BUFR MESSAGE THAT IS TO BE DECODED; EARLIEST -C - DATE IS "IDATE" + "IHE" HOURS (IF "IHE" IS POSITIVE, -C - LATEST MESSAGE DATE IS AFTER "IDATE"; IF "IHE" IS -C - NEGATIVE LATEST MESSAGE DATE IS PRIOR TO "IDATE") -C - EXAMPLE: IF IHE=1, THEN EARLIEST DATE IS 1-HR AFTER -C - IDATE; IF IHE=-3, THEN EARLIEST DATE IS 3-HR PRIOR -C - TO IDATE -C IHL - NUMBER OF WHOLE HOURS RELATIVE TO "IDATE" FOR DATE OF -C - LATEST BUFR MESSAGE THAT IS TO BE DECODED; LATEST -C - DATE IS "IDATE" + ("IHL" HOURS PLUS 59 MIN) IF "IHL" -C - IS POSITIVE (LATEST MESSAGE DATE IS AFTER "IDATE"), -C - AND "IDATE" + ("IHL"+1 HOURS MINUS 1 MIN) IF "IHL" -C - IS NEGATIVE (LATEST MESSAGE DATE IS PRIOR TO "IDATE") -C - EXAMPLE: IF IHL=3, THEN LATEST DATE IS 3-HR 59-MIN -C - AFTER IDATE; IF IHL=-2, THEN LATEST DATE IS 1-HR 1-MIN -C - PRIOR TO IDATE -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C IRET - CONTROLS DEGREE OF UNIT 6 PRINTOUT (.GE. 0 -LIMITED -C - PRINTOUT; = -1 SOME ADDITIONAL DIAGNOSTIC PRINTOUT; -C = .LT. -1 -EXTENSIVE PRINTOUT) (SEE REMARKS 3.) -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE REPORT RETURNED AN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT (SEE REMARKS 4.) (MINIMUM SIZE IS -C - 1200 WORDS) -C IRET - RETURN CODE AS FOLLOWS: -C IRET = 0 ---> REPORT SUCCESSFULLY RETURNED -C IRET > 0 ---> NO REPORT RETURNED DUE TO: -C = 1 ---> ALL REPORTS READ IN, END -C = 2 ---> LAT AND/OR LON DATA MISSING -C = 3 ---> RESERVED -C = 4 ---> SOME/ALL DATE INFORMATION MISSING -C = 5 ---> NO DATA LEVELS PROCESSED (ALL LEVELS ARE MISSING) -C = 6 ---> NUMBER OF LEVELS IN REPORT HEADER IS NOT 1 -C = 7 ---> NUMBER OF LEVELS IN ANOTHER SINGLE LEVEL SEQUENCE -C IS NOT 1 -C -C INPUT FILES: -C UNIT AA - (WHERE AA IS LUNIT ABOVE) FILE HOLDING THE DATA -C - IN THE FORM OF BUFR MESSAGES -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C SUBPROGRAMS CALLED: -C UNIQUE - UNPK7701 UNPK7702 UNPK7703 UNPK7704 UNPK7705 -C - UNPK7706 UNPK7707 UNPK7708 UNPK7709 -C LIBRARY: -C W3LIB - W3FI04 W3MOVDAT W3DIFDAT ERREXIT -C BUFRLIB - DATELEN DUMPBF OPENBF READMG UFBCNT -C - READSB UFBINT CLOSBF -C -C REMARKS: 1) A CONDITION CODE (STOP) OF 15 WILL OCCUR IF THE INPUT -C DATES FOR START AND/OR STOP TIME ARE SPECIFIED INCORRECTLY. -C 2) A CONDITION CODE (STOP) OF 22 WILL OCCUR IF THE -C CHARACTERS ON THIS MACHINE ARE NEITHER ASCII NOR EBCDIC. -C 3) THE INPUT ARGUMENT "IRET" SHOULD BE SET PRIOR TO EACH -C CALL TO THIS SUBROUTINE. -C -C *************************************************************** -C 4) -C BELOW IS THE FORMAT OF AN UNPACKED REPORT IN OUTPUT ARRAY RDATA -C (EACH WORD REPRESENTS A FULL-WORD ACCORDING TO THE MACHINE) -C N O T E : THIS IS THE SAME FORMAT AS FOR W3LIB ROUTINE W3FI77 -C EXCEPT WHERE NOTED -C *************************************************************** -C -CXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -C FORMAT FOR WIND PROFILER REPORTS -CXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -C HEADER -C WORD CONTENT UNIT FORMAT -C ---- ---------------------- ------------------- --------- -C 1 LATITUDE 0.01 DEGREES REAL -C 2 LONGITUDE 0.01 DEGREES WEST REAL -C 3 TIME SIGNIFICANCE (BUFR CODE TABLE "0 08 021") INTEGER -C 4 OBSERVATION TIME 0.01 HOURS (UTC) REAL -cvvvvvdak port -C 5 YEAR/MONTH 4-CHAR. 'YYMM' CHARACTER -caaaaadak port -C LEFT-JUSTIFIED -C 6 DAY/HOUR 4-CHARACTERS 'DDHH' CHARACTER -C 7 STATION ELEVATION METERS REAL -C 8 SUBMODE/EDITION NO. (SM X 10) + ED. NO. INTEGER -C (ED. NO.=2, CONSTANT; SEE &,~) -C 9 REPORT TYPE 71 (CONSTANT) INTEGER -C 10 AVERAGING TIME MINUTES INTEGER -C (NEGATIVE MEANS PRIOR TO OBS. TIME) -C 11 STN. ID. (FIRST 4 CHAR.) 4-CHARACTERS CHARACTER -C LEFT-JUSTIFIED -C 12 STN. ID. (LAST 2 CHAR.) 2-CHARACTERS CHARACTER -C LEFT-JUSTIFIED -C -C 13-34 ZEROED OUT - NOT USED INTEGER -C 35 CATEGORY 10, NO. LEVELS COUNT INTEGER -C 36 CATEGORY 10, DATA INDEX COUNT INTEGER -C 37 CATEGORY 11, NO. LEVELS COUNT INTEGER -C 38 CATEGORY 11, DATA INDEX COUNT INTEGER -C 39-42 ZEROED OUT - NOT USED INTEGER -C -C 43-END UNPACKED DATA GROUPS (FOLLOWS) REAL -C -C CATEGORY 10 - WIND PROFILER SFC DATA (EACH LEVEL, SEE WORD 35 ABOVE) -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C(SEE @)1 SEA-LEVEL PRESSURE 0.1 MILLIBARS REAL -C(SEE *)2 STATION PRESSURE 0.1 MILLIBARS REAL -C(SEE @)3 HORIZ. WIND DIR. DEGREES REAL -C(SEE @)4 HORIZ. WIND SPEED 0.1 M/S REAL -C(SEE @)5 AIR TEMPERATURE 0.1 DEGREES K REAL -C(SEE @)6 RELATIVE HUMIDITY PERCENT REAL -C(SEE @)7 RAINFALL RATE 0.0000001 M/S REAL -C -C CATEGORY 11 - WIND PROFILER UPPER-AIR DATA (FIRST LEVEL IS SURFACE) -C (EACH LEVEL, SEE WORD 37 ABOVE) -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 HEIGHT ABOVE SEA-LVL METERS REAL -C 2 HORIZ. WIND DIR. DEGREES REAL -C 3 HORIZ. WIND SPEED 0.1 M/S REAL -C 4 QUALITY CODE (SEE %) INTEGER -C 5 VERT. WIND COMP. (W) 0.01 M/S REAL -C(SEE @)6 HORIZ. CONSENSUS NO. (SEE $) INTEGER -C(SEE @)7 VERT. CONSENSUS NO. (SEE $) INTEGER -C(SEE @)8 SPECTRAL PEAK POWER DB REAL -C 9 HORIZ. WIND SPEED 0.1 M/S REAL -C STANDARD DEVIATION 0.1 M/S REAL -C 10 VERT. WIND COMPONENT 0.1 M/S REAL -C STANDARD DEVIATION 0.1 M/S REAL -C(SEE @)11 MODE (SEE #) INTEGER -C -C *- ALWAYS MISSING -C &- THIS IS A CHANGE FROM FORMAT IN W3LIB ROUTINE W3FI77 -C %- 0 - MEDIAN AND SHEAR CHECKS BOTH PASSED -C 2 - MEDIAN AND SHEAR CHECK RESULTS INCONCLUSIVE -C 4 - MEDIAN CHECK PASSED; SHEAR CHECK FAILED -C 8 - MEDIAN CHECK FAILED; SHEAR CHECK PASSED -C 12 - MEDIAN AND SHEAR CHECKS BOTH FAILED -C $- NO. OF INDIVIDUAL 6-MINUTE AVERAGE MEASUREMENTS THAT WERE -C INCLUDED IN FINAL ESTIMATE OF AVERAGED WIND (RANGE: 0, 2-10) -C (BASED ON A ONE-HOUR AVERAGE) -C #- 1 - DATA FROM LOW MODE -C 2 - DATA FROM HIGH MODE -C 3 - MISSING -C @- THIS PARAMETER IS NO LONGER AVAILABLE AFTER 3/2002 AND IS SET -C TO MISSING (99999 FOR INTEGER OR 99999. FOR REAL) -C ~- SUBMODE IS NO LONGER AVAILABLE AFTER 3/2002 AND IS SET TO 3 -C (ITS MISSING VALUE) -C -CXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -C FORMAT FOR GOES SOUNDING/RADIANCE REPORTS -CXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -C HEADER -C WORD CONTENT UNIT FORMAT -C ---- ---------------------- ------------------- --------- -C 1 LATITUDE 0.01 DEGREES REAL -C 2 LONGITUDE 0.01 DEGREES WEST REAL -C 3 FIELD OF VIEW NUMBER NUMERIC INTEGER -C 4 OBSERVATION TIME 0.01 HOURS (UTC) REAL -cvvvvvdak port -C 5 YEAR/MONTH 4-CHAR. 'YYMM' CHARACTER -caaaaadak port -C LEFT-JUSTIFIED -C 6 DAY/HOUR 4-CHARACTERS 'DDHH' CHARACTER -C 7 STATION ELEVATION METERS REAL -C 8 PROCESS. TECHNIQUE (=21-CLEAR; INTEGER -C 8 PROCESS. TECHNIQUE =23-CLOUD-CORRECTED) -C 9 REPORT TYPE 61 (CONSTANT) INTEGER -C 10 QUALITY FLAG (BUFR CODE TABLE "0 33 002") INTEGER -C 11 STN. ID. (FIRST 4 CHAR.) 4-CHARACTERS CHARACTER -C LEFT-JUSTIFIED -C 12 STN. ID. (LAST 2 CHAR.) 2-CHARACTERS CHARACTER -C LEFT-JUSTIFIED (SEE %) -C -C 13-26 ZEROED OUT - NOT USED -C 27 CATEGORY 08, NO. LEVELS COUNT INTEGER -C 28 CATEGORY 08, DATA INDEX COUNT INTEGER -C 29-38 ZEROED OUT - NOT USED -C 39 CATEGORY 12, NO. LEVELS COUNT INTEGER -C 40 CATEGORY 12, DATA INDEX COUNT INTEGER -C 41 CATEGORY 13, NO. LEVELS COUNT INTEGER -C 42 CATEGORY 13, DATA INDEX COUNT INTEGER -C -C 43-END UNPACKED DATA GROUPS (FOLLOWS) REAL -C -C CATEGORY 12 - SATELLITE SOUNDING LEVEL DATA (FIRST LEVEL IS SURFACE; -C EACH LEVEL, SEE 39 ABOVE) -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 PRESSURE 0.1 MILLIBARS REAL -C 2 GEOPOTENTIAL METERS REAL -C 3 TEMPERATURE 0.1 DEGREES C REAL -C 4 DEWPOINT TEMPERATURE 0.1 DEGREES C REAL -C 5 NOT USED SET TO MISSING REAL -C 6 NOT USED SET TO MISSING REAL -C 7 QUALITY MARKERS 4-CHARACTERS CHARACTER -C LEFT-JUSTIFIED (SEE &) -C -C CATEGORY 13 - SATELLITE RADIANCE "LEVEL" DATA (EACH "LEVEL", SEE -C 41 ABOVE) -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 CHANNEL NUMBER NUMERIC INTEGER -C 2 BRIGHTNESS TEMP. 0.01 DEG. KELVIN REAL -C 3 QUALITY MARKERS 4-CHARACTERS CHARACTER -C LEFT-JUSTIFIED (SEE &&) -C -C CATEGORY 08 - ADDITIONAL (MISCELLANEOUS) DATA (EACH LEVEL, SEE @ -C BELOW) -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 VARIABLE SEE @ BELOW REAL -C 2 CODE FIGURE SEE @ BELOW REAL -C 3 MARKERS 2-CHARACTERS CHARACTER -C LEFT-JUSTIFIED (SEE #) -C -C %- SIXTH CHARACTER OF STATION ID IS A TAGGED AS FOLLOWS: -C "I" - GOES-EVEN-1 (252, 256, ...) SAT. , CLEAR COLUMN RETR. -C "J" - GOES-EVEN-1 (252, 256, ...) SAT. , CLD-CORRECTED RETR. - -C "L" - GOES-ODD-1 (253, 257, ...) SAT. , CLEAR COLUMN RETR. -C "M" - GOES-ODD-1 (253, 257, ...) SAT. , CLD-CORRECTED RETR. - -C "O" - GOES-EVEN-2 (254, 258, ...) SAT. , CLEAR COLUMN RETR. -C "P" - GOES-EVEN-2 (254, 258, ...) SAT. , CLD-CORRECTED RETR. - -C "Q" - GOES-ODD-2 (251, 255, ...) SAT. , CLEAR COLUMN RETR. -C "R" - GOES-ODD-2 (251, 255, ...) SAT. , CLD-CORRECTED RETR. - -C "?" - EITHER SATELLITE AND/OR RETRIEVAL TYPE UNKNOWN - -C &- FIRST CHARACTER IS Q.M. FOR GEOPOTENTIAL -C SECOND CHARACTER IS Q.M. FOR TEMPERATURE -C THIRD CHARACTER IS Q.M. FOR DEWPOINT TEMPERATURE -C FOURTH CHARACTER IS NOT USED -C " " - INDICATES DATA NOT SUSPECT -C "Q" - INDICATES DATA ARE SUSPECT -C "F" - INDICATES DATA ARE BAD -C &&- FIRST CHARACTER IS Q.M. FOR BRIGHTNESS TEMPERATURE -C SECOND-FOURTH CHARACTERS ARE NOT USED -C " " - INDICATES DATA NOT SUSPECT -C "Q" - INDICATES DATA ARE SUSPECT -C "F" - INDICATES DATA ARE BAD -C @- NUMBER OF "LEVELS" FROM WORD 27. MAXIMUM IS 12, AND ARE ORDERED -C AS FOLLOWS (IF A DATUM ARE MISSING THAT LEVEL NOT STORED) -C 1 - LIFTED INDEX ---------- .01 DEG. KELVIN -- C. FIG. 250. -C 2 - TOTAL PRECIP. WATER -- .01 MILLIMETERS -- C. FIG. 251. -C 3 - 1. TO .9 SIGMA P.WATER- .01 MILLIMETERS -- C. FIG. 252. -C 4 - .9 TO .7 SIGMA P.WATER- .01 MILLIMETERS -- C. FIG. 253. -C 5 - .7 TO .3 SIGMA P.WATER- .01 MILLIMETERS -- C. FIG. 254. -C 6 - SKIN TEMPERATURE ----- .01 DEG. KELVIN -- C. FIG. 255. -C 7 - CLOUD TOP TEMPERATURE- .01 DEG. KELVIN -- C. FIG. 256. -C 8 - CLOUD TOP PRESSURE --- .1 MILLIBARS ----- C. FIG. 257. -C 9 - CLOUD AMOUNT (BUFR TBL. C.T. 0-20-011) -- C. FIG. 258. -C 10 - INSTR. DATA USED IN PROC. -C (BUFR TBL. C.T. 0-02-021) -- C. FIG. 259. -C 11 - SOLAR ZENITH ANGLE --- .01 DEGREE ------- C. FIG. 260. -C 12 - SAT. ZENITH ANGLE ---- .01 DEGREE ------- C. FIG. 261. -C #- FIRST CHARACTER IS Q.M. FOR THE DATUM -C " " - INDICATES DATA NOT SUSPECT -C "Q" - INDICATES DATA ARE SUSPECT -C "F" - INDICATES DATA ARE BAD -C SECOND CHARACTER IS NOT USED -C -CXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -C FORMAT FOR NEXRAD (VAD) WIND REPORTS -CXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -C HEADER -C WORD CONTENT UNIT FORMAT -C ---- ---------------------- ------------------- --------- -C 1 LATITUDE 0.01 DEGREES REAL -C 2 LONGITUDE 0.01 DEGREES WEST REAL -C 3 ** RESERVED ** SET TO 99999 INTEGER -C 4 OBSERVATION TIME 0.01 HOURS (UTC) REAL -cvvvvvdak port -C 5 YEAR/MONTH 4-CHAR. 'YYMM' CHARACTER -caaaaadak port -C LEFT-JUSTIFIED -C 6 DAY/HOUR 4-CHARACTERS 'DDHH' CHARACTER -C 7 STATION ELEVATION METERS REAL -C 8 ** RESERVED ** SET TO 99999 INTEGER -C -C 9 REPORT TYPE 72 (CONSTANT) INTEGER -C 10 ** RESERVED ** SET TO 99999 INTEGER -C 11 STN. ID. (FIRST 4 CHAR.) 4-CHARACTERS CHARACTER -C LEFT-JUSTIFIED -C 12 STN. ID. (LAST 2 CHAR.) 2-CHARACTERS CHARACTER -C LEFT-JUSTIFIED -C -C 13-18 ZEROED OUT - NOT USED INTEGER -C 19 CATEGORY 04, NO. LEVELS COUNT INTEGER -C 20 CATEGORY 04, DATA INDEX COUNT INTEGER -C 21-42 ZEROED OUT - NOT USED INTEGER -C -C 43-END UNPACKED DATA GROUPS (FOLLOWS) REAL -C -C CATEGORY 04 - UPPER-AIR WINDS-BY-HEIGHT DATA(FIRST LEVEL IS SURFACE) -C (EACH LEVEL, SEE WORD 19 ABOVE) -C WORD PARAMETER UNITS FORMAT -C ---- --------- ----------------- ------------- -C 1 HEIGHT ABOVE SEA-LVL METERS REAL -C 2 HORIZ. WIND DIR. DEGREES REAL -C 3 HORIZ. WIND SPEED 0.1 M/S (SEE *) REAL -C 4 QUALITY MARKERS 4-CHARACTERS CHARACTER -C LEFT-JUSTIFIED (SEE %) -C -C *- UNITS HERE DIFFER FROM THOSE IN TRUE UNPACKED OFFICE NOTE 29 -C (WHERE UNITS ARE KNOTS) -C %- THE FIRST THREE CHARACTERS ARE ALWAYS BLANK, THE FOURTH -C CHARACTER IS A "CONFIDENCE LEVEL" WHICH IS RELATED TO THE ROOT- -C MEAN-SQUARE VECTOR ERROR FOR THE HORIZONTAL WIND. IT IS -C DEFINED AS FOLLOWS: -C 'A' = RMS OF 1.9 KNOTS -C 'B' = RMS OF 3.9 KNOTS -C 'C' = RMS OF 5.8 KNOTS -C 'D' = RMS OF 7.8 KNOTS -C 'E' = RMS OF 9.7 KNOTS -C 'F' = RMS OF 11.7 KNOTS -C 'G' = RMS > 13.6 KNOTS -CXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -C -C FOR ALL REPORT TYPES, MISSING VALUES ARE: -C 99999. FOR REAL -C 99999 FOR INTEGER -C 9'S FOR CHARACTERS IN WORD 5, 6 OF HEADER -C BLANK FOR CHARACTERS IN WORD 11, 12 OF HEADER -C AND FOR CHARACTERS IN ANY CATEGORY LEVEL -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE W3UNPK77(IDATE,IHE,IHL,LUNIT,RDATA,IRET) - CHARACTER*4 CBUFR - INTEGER IDATE(4),LSDATE(4),jdate(8),IDATA(1200) - dimension rinc(5) - REAL RDATA(*),RDATX(1200) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - COMMON /PK77CC/INDEX - COMMON /PK77DD/LSHE,LSHL,ICDATE(5),IDDATE(5) - COMMON /PK77FF/IFOV(3),KNTSAT(250:260) - - SAVE - - EQUIVALENCE (RDATX,IDATA) - DATA ITM/0/,LUNITL/-99/,KOUNT/0/ - IPRINT = 0 - IF(IRET.LT.0) IPRINT = IABS(IRET) - IRET = 0 - IF(ITM.EQ.0) THEN -C----------------------------------------------------------------------- - -C FIRST AND ONLY TIME INTO THIS SUBROUTINE DO A FEW THINGS.... - - ITM = 1 - IFOV = 0 - KNTSAT = 0 -C DETERMINE MACHINE WORD LENGTH IN BYTES (=8 FOR CRAY) AND TYPE OF -C CHARACTER SET {ASCII(ICHTP=0) OR EBCDIC(ICHTP=1)} - CALL W3FI04(IENDN,ICHTP,LW) - PRINT 2213, LW, ICHTP, IENDN - 2213 FORMAT(/' ---> W3UNPK77: CALL TO W3FI04 RETURNS: LW = ',I3, - $ ', ICHTP = ',I3,', IENDN = ',I3/) - IF(ICHTP.GT.1) THEN -C CHARACTERS ON THIS MACHINE ARE NEITHER ASCII OR EBCDIC!! -- STOP 22 - PRINT 217 - 217 FORMAT(' *** W3UNPK77 ERROR: CHARACTERS ON THIS MACHINE ', - $ 'ARE NEITHER ASCII NOR EBCDIC - STOP 22'/) - CALL ERREXIT(22) - END IF -C----------------------------------------------------------------------- - END IF - IF(LUNIT.NE.LUNITL) THEN -C----------------------------------------------------------------------- - -C IF THE INPUT DATA UNIT NUMBER ARGUMENT IS DIFFERENT THAT THE LAST TIME -C THIS SUBR. WAS CALLED, PRINT NEW HEADER, SET JRET = 1 - - LUNITL = LUNIT - JRET = 1 - PRINT 101, LUNIT - 101 FORMAT(//' ---> W3UNPK77: VERSION 03/05/2002: JBUFR DATA SET ', - $ 'READ FROM UNIT ',I4/) -C----------------------------------------------------------------------- - ELSE - -C FOR SUBSEQUENT TIMES INTO THIS SUBR. W/ SAME LUNIT AS LAST TIME, -C TEST INPUT DATE & HR RANGE ARGUMENTS AGAINST THEIR VALUES THE LAST -C TIME SUBR. CALLED -- IF THEY ARE DIFFERENT, SET JRET = 1 (ELSE -C JRET = 0), WILL TEST JRET SOON - - JRET = 1 - DO I = 4,1,-1 - IF(IDATE(I).NE.LSDATE(I)) GO TO 88 - ENDDO - IF(IHE.NE.LSHE.OR.IHL.NE.LSHL) GO TO 88 - JRET = 0 - 88 CONTINUE -C----------------------------------------------------------------------- - END IF - IF(JRET.EQ.1) THEN - PRINT 6680 - 6680 FORMAT(/' JRET = 1 - REWIND DATA FILE & SET-UP TO DO DATE CHECK'/) -C----------------------------------------------------------------------- - -C COME HERE IF FIRST CALL TO SUBROUTINE OR IF INPUT DATA UNIT NUMBER OR -C IF INPUT DATE/TIME OR RANGE IN TIME HAS BEEN CHANGED FROM LAST CALL - -C CLOSE BUFR DATA SET (IN CASE OPEN FROM PREVIOUS RUN) -C REWIND INPUT BUFR DATA SET, GET CENTER TIME AND DUMP TIME, -C OPEN BUFR DATA SET - -C SET-UP TO DETERMINE IF BUFR MESSAGE IS WITHIN REQUESTED DATES - -C (ALSO SET INDEX=0, FORCES BUFR MSG TO BE READ BEFORE RPTS ARE DECODED) - -C----------------------------------------------------------------------- - - CALL CLOSBF(LUNIT) - - REWIND LUNIT - - READ(LUNIT,END=9999,ERR=9999) CBUFR - IF(CBUFR.NE.'BUFR') GO TO 9999 - - call datelen(10) - - CALL DUMPBF(LUNIT,ICDATE,IDDATE) -cppppp - print *,'CENTER DATE (ICDATE) = ',icdate - print *,'DUMP DATE (IDDATE) = ',iddate -cppppp - - if(icdate(1).le.0) then -C COME HERE IF CENTER DATE COULD NOT BE READ FROM FIRST DUMMY MESSAGE -C - RETURN WITH IRET = 1 - print *, ' *** W3UNPK77 ERROR: CENTER DATE COULD NOT BE ', - $ 'OBTAINED FROM INPUT FILE ON UNIT ',lunit - go to 9998 - end if - if(iddate(1).le.0) then -C COME HERE IF DUMP DATE COULD NOT BE READ FROM SECOND DUMMY MESSAGE -C - RETURN WITH IRET = 1 - print *, ' *** W3UNPK77 ERROR: DUMP DATE COULD NOT BE ', - $ 'OBTAINED FROM INPUT FILE ON UNIT ',lunit - go to 9998 - end if - IF(ICDATE(1).LT.100) THEN - -C If 2-digit year returned in ICDATE(1), must use "windowing" technique -C to create a 4-digit year - -C IMPORTANT: IF DATELEN(10) IS CALLED, THE DATE HERE SHOULD ALWAYS -C CONTAIN A 4-DIGIT YEAR, EVEN IF INPUT FILE IS NOT -C Y2K COMPLIANT (BUFRLIB DOES THE WINDOWING HERE) - - PRINT *, '##W3UNPK77 - THE FOLLOWING SHOULD NEVER ', - $ 'HAPPEN!!!!!' - PRINT *, '##W3UNPK77 - 2-DIGIT YEAR IN ICDATE(1) ', - $ 'RETURNED FROM DUMPBF (ICDATE IS: ',ICDATE,') - USE ', - $ 'WINDOWING TECHNIQUE TO OBTAIN 4-DIGIT YEAR' - IF(ICDATE(1).GT.20) THEN - ICDATE(1) = 1900 + ICDATE(1) - ELSE - ICDATE(1) = 2000 + ICDATE(1) - ENDIF - PRINT *, '##WW3UNPK77 - CORRECTED ICDATE(1) WITH 4-DIGIT ', - $ 'YEAR, ICDATE NOW IS: ',ICDATE - ENDIF - - IF(IDDATE(1).LT.100) THEN - -C If 2-digit year returned in IDDATE(1), must use "windowing" technique -C to create a 4-digit year - -C IMPORTANT: IF DATELEN(10) IS CALLED, THE DATE HERE SHOULD ALWAYS -C CONTAIN A 4-DIGIT YEAR, EVEN IF INPUT FILE IS NOT -C Y2K COMPLIANT (BUFRLIB DOES THE WINDOWING HERE) - - PRINT *, '##W3UNPK77 - THE FOLLOWING SHOULD NEVER ', - $ 'HAPPEN!!!!!' - PRINT *, '##W3UNPK77 - 2-DIGIT YEAR IN IDDATE(1) ', - $ 'RETURNED FROM DUMPBF (IDDATE IS: ',IDDATE,') - USE ', - $ 'WINDOWING TECHNIQUE TO OBTAIN 4-DIGIT YEAR' - IF(IDDATE(1).GT.20) THEN - IDDATE(1) = 1900 + IDDATE(1) - ELSE - IDDATE(1) = 2000 + IDDATE(1) - ENDIF - PRINT *, '##W3UNPK77 - CORRECTED IDDATE(1) WITH 4-DIGIT ', - $ 'YEAR, IDDATE NOW IS: ',IDDATE - END IF - -C OPEN BUFR FILE - READ IN DICTIONARY MESSAGES (TABLE A, B, D ENTRIES) - - CALL OPENBF(LUNIT,'IN',LUNIT) - PRINT 100, LUNIT - 100 FORMAT(/5X,'===> BUFR DATA SET IN UNIT',I3,' SUCCESSFULLY ', - $ 'OPENED FOR INPUT; DCTNY MESSAGES CONTAIN BUFR TABLES A,B,D'/) - INDEX = 0 - KOUNT = 0 - jdate(1:3) = idate(1:3) - jdate(4) = 0 - jdate(5) = idate(4) - jdate(6:8) = 0 - PRINT 6681, IDATE - 6681 FORMAT(/' %%% REQUESTED "CENTRAL" DATE IS :',I5,3I3,' 0'/) -C DETERMINE EARLIEST DATE FOR ACCEPTING BUFR MESSAGES FOR DECODING - call w3movdat((/0.,real(ihe),0.,0.,0./),jdate,kdate) - print 6682, (kdate(i),i=1,3),kdate(5),kdate(6) - 6682 FORMAT(/' --> EARLIEST DATE FOR ACCEPTING BUFR MSGS IS:',I5,4I3/) -C DETERMINE LATEST DATE FOR ACCEPTING BUFR MESSAGES FOR DECODING - if(ihl.ge.0) then - xminl = (ihl * 60) + 59 - else - xminl = ((ihl + 1) * 60) - 1 - end if - call w3movdat((/0.,0.,xminl,0.,0./),jdate,ldate) - print 6683, (ldate(i),i=1,3),ldate(5),ldate(6) - 6683 FORMAT(/' --> LATEST DATE FOR ACCEPTING BUFR MSGS IS:',I5,4I3/) - call w3difdat(ldate,kdate,3,rinc) - IF(rinc(3).LT.0) THEN - PRINT 104 - 104 FORMAT(' *** W3UNPK77 ERROR: DATES SPECIFIED INCORRECTLY -', - $ ' STOP 15'/) - CALL ERREXIT(15) - END IF -C----------------------------------------------------------------------- - END IF -C SUBR. UNPK7701 RETURNS A SINGLE DECODED REPORT FROM BUFR MESSAGE - CALL UNPK7701(LUNIT,ITP,IRET) -C IRET=1 MEANS ALL DATA HAVE BEEN DECODED FOR SPECIFIED TIME PERIOD -C (REWIND DATA FILE AND RETURN W/ IRET=1) -C IRET.GE.2 MEANS REPORT NOT RETURNED DUE TO ERROR IN DECODING (RETURN) -C (ACTUALLY IRET.GE.2 CURRENTLY CANNOT HAPPEN OUT OF UNPK7701) - IF(IRET.GE.1) THEN - IF(IRET.EQ.1) THEN - REWIND LUNIT - IF(ITP.EQ.2) THEN - PRINT 8101, IFOV - 8101 FORMAT(/' ---> W3UNPK77: SUMMARY OF GOES REPORT COUNTS GROUPED', - $ ' BY F-O-V NO. (PRIOR TO ANY FILTERING BY CALLING PROGRAM)'/15X, - $ '# WITH F-O-V NO. 00 TO 02:',I6,' - GET "BAD" Q.MARK'/15X, - $ '# WITH F-O-V NO. 03 TO 09:',I6,' - GET "SUSPECT" Q.MARK'/15X, - $ '# WITH F-O-V NO. 10 TO 25:',I6,' - GET "NEUTRAL" Q.MARK'/20X, - $ '(NOTE: RADIANCES ALWAYS HAVE NEUTRAL Q.MARK)'/) - PRINT 8102 - 8102 FORMAT(/' ---> W3UNPK77: SUMMARY OF GOES REPORT COUNTS GROUPED', - $ ' BY SATELLITE ID (PRIOR TO ANY FILTERING BY CALLING PROGRAM)'/) - DO IDSAT = 250,259 - IF(KNTSAT(IDSAT).GT.0) PRINT 8103, IDSAT,KNTSAT(IDSAT) - ENDDO - 8103 FORMAT(15X,'NUMBER FROM SAT. ID',I4,4X,':',I6) - IF(KNTSAT(260).GT.0) PRINT 8104 - 8104 FORMAT(15X,'NUMBER FROM UNKNOWN SAT. ID:',I6) - PRINT 8105 - 8105 FORMAT(/) - END IF - END IF - GO TO 99 - END IF - KOUNT = KOUNT + 1 -C INITIALIZE THE OUTPUT ON29 ARRAY - CALL UNPK7702(RDATA,ITP) - IF(ITP.EQ.1) THEN -C----------------------------------------------------------------------- -C THE FOLLOWING PERTAINS TO WIND PROFILER REPORTS -C----------------------------------------------------------------------- -C STORE THE HEADER INFORMATION INTO ON29 FORMAT - CALL UNPK7703(LUNIT,RDATA,IRET) -C IRET.GE.2 MEANS RPT NOT RETURNED DUE TO MSG DATA IN HDR (RETURN) - IF(IRET.GE.2) GO TO 99 -C STORE THE SURFACE DATA INTO ON29 FORMAT (CATEGORY 10) - CALL UNPK7704(LUNIT,RDATA) -C STORE THE UPPER-AIR DATA INTO ON29 FORMAT (CATEGORY 11) - CALL UNPK7705(LUNIT,RDATA) - RDATX(1:1200) = RDATA(1:1200) - IF(IDATA(35)+IDATA(37).EQ.0) IRET = 5 - ELSE IF(ITP.EQ.2) THEN -C----------------------------------------------------------------------- -C THE FOLLOWING PERTAINS TO GOES SOUNDING/RADIANCE REPORTS -C----------------------------------------------------------------------- -C STORE THE HEADER INFORMATION INTO ON29 FORMAT - CALL UNPK7708(LUNIT,RDATA,KOUNT,IRET) -C IRET.GE.2 MEANS RPT NOT RETURNED DUE TO MSG DATA IN HDR (RETURN) - IF(IRET.GE.2) GO TO 99 -C STORE THE UPPER-AIR DATA/RADIANCE INTO ON29 FORMAT (CATEGORY 12, 13) - CALL UNPK7709(LUNIT,RDATA,IRET) - ELSE IF(ITP.EQ.3) THEN -C----------------------------------------------------------------------- -C THE FOLLOWING PERTAINS TO NEXRAD (VAD) WIND REPORTS -C----------------------------------------------------------------------- -C STORE THE HEADER INFORMATION INTO ON29 FORMAT - CALL UNPK7706(LUNIT,RDATA,IRET) -C IRET.GE.2 MEANS RPT NOT RETURNED DUE TO MSG DATA IN HDR (RETURN) - IF(IRET.GE.2) GO TO 99 -C STORE THE UPPER-AIR DATA INTO ON29 FORMAT (CATEGORY 4) - CALL UNPK7707(LUNIT,RDATA,IRET) -C----------------------------------------------------------------------- - END IF - 99 CONTINUE -C PRIOR TO RETURNING SAVE INPUT DATE & HR RANGE ARGUMENTS FROM THIS CALL - lsdate = idate - LSHE = IHE - LSHL = IHL - RETURN -C----------------------------------------------------------------------- - 9999 CONTINUE -C COME HERE IF NULL OR NON-BUFR FILE IS INPUT - RETURN WITH IRET = 1 - PRINT *, ' *** W3UNPK77 ERROR: INPUT FILE IN UNIT ',LUNIT,' IS ', - $ 'EITHER A NULL OR NON-BUFR FILE' - 9998 continue - REWIND LUNIT - IRET = 1 - lsdate = idate - LSHE = IHE - LSHL = IHL - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7701 READS A SINGLE REPORT OUT OF BUFR DATASET -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 1996-12-16 -C -C ABSTRACT: CALLS BUFRLIB ROUTINES TO READ IN A BUFR MESSAGE AND THEN -C READ A SINGLE REPORT (SUBSET) OUT OF THE MESSAGE. -C -C PROGRAM HISTORY LOG: -C 1996-12-16 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C -C USAGE: CALL UNPK7701(LUNIT,ITP,IRET) -C INPUT ARGUMENT LIST: -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C ITP - THE TYPE OF REPORT THAT HAS BEEN DECODED {=1 - -C - WIND PROFILER, =2 - GOES SNDG, =3 - NEXRAD(VAD) WIND} -C IRET - RETURN CODE AS DESCRIBED IN W3UNPK77 DOCBLOCK -C -C INPUT FILES: -C UNIT AA - (WHERE AA IS LUNIT ABOVE) FILE HOLDING THE DATA -C - IN THE FORM OF BUFR MESSAGES -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBROUTINE W3UNPK77. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7701(LUNIT,ITP,IRET) - CHARACTER*8 SUBSET - integer mdate(4),ndate(8) - dimension rinc(5) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - COMMON /PK77CC/INDEX - COMMON /PK77DD/LSHE,LSHL,ICDATE(5),IDDATE(5) - - SAVE - - DATA IREC/0/ - - 10 CONTINUE -C======================================================================= - IF(INDEX.EQ.0) THEN - -C READ IN NEXT BUFR MESSAGE - - CALL READMG(LUNIT,SUBSET,IBDATE,JRET) - IF(JRET.NE.0) THEN -C----------------------------------------------------------------------- - PRINT 101 - 101 FORMAT(' ---> W3UNPK77: ALL BUFR MESSAGES READ IN AND DECODED'/) - IRET = 1 - RETURN -C----------------------------------------------------------------------- - END IF - if(ibdate.lt.100000000) then -c If input BUFR file does not return messages with a 4-digit year, -c something is wrong (even non-compliant BUFR messages should -c construct a 4-digit year as long as datelen(10) has been called - print *, '##W3UNP777/UNPK7701 - A 10-digit Sect. 1 BUFR ', - $ 'message date was not returned in unit ',lunit,' - ', - $ 'problem with BUFR file - ier = 1' - iret = 1 - return - end if - CALL UFBCNT(LUNIT,IREC,ISUB) - MDATE(1) = IBDATE/1000000 - MDATE(2) = MOD((IBDATE/10000),100) - MDATE(3) = MOD((IBDATE/100),100) - MDATE(4) = MOD(IBDATE,100) -C ALL JBUFR MESSAGES CURRENTLY HAVE "00" FOR MINUTES IN SECTION 1 - ndate(1:3) = mdate(1:3) - ndate(4) = 0 - ndate(5) = mdate(4) - ndate(6:8) = 0 - IF(IPRINT.GE.1) THEN - PRINT *,'HAVE SUCCESSFULLY READ IN A BUFR MESSAGE' - PRINT 103 - 103 FORMAT(' BUFR FOUND BEGINNING AT BYTE 1 OF MESSAGE') - PRINT 105, IREC,MDATE,SUBSET - 105 FORMAT(8X,'HAVE READ IN A BUFR MESSAGE NO.',I3,', DATE: ', - $ I6,3I4,' 0; TABLE A ENTRY = ',A8,' AND EDIT. NO. = 2'/) - END IF - IF(SUBSET.EQ.'NC002007') THEN - IF(IPRINT.GE.1) PRINT *, 'THIS MESSAGE CONTAINS WIND ', - $ 'PROFILER REPORTS' - ITP = 1 - ELSE IF(SUBSET.EQ.'NC002008') THEN - IF(IPRINT.GE.1) PRINT *, 'THIS MESSAGE CONTAINS NEXRAD ', - $ '(VAD) WIND REPORTS' - ITP = 3 - ELSE IF(SUBSET.EQ.'NC003001') THEN - IF(IPRINT.GE.1) PRINT *, 'THIS MESSAGE CONTAINS GOES ', - $ 'SOUNDING/RADIANCE REPORTS' - ITP = 2 - ELSE - PRINT 107, IREC - 107 FORMAT(' *** W3UNPK77 WARNING: BUFR MESSAGE NO.',I3,' CONTAINS ', - $ 'REPORTS THAT CANNOT BE DECODED BY W3UNPK77, TRY READING NEXT ', - $ 'MSG'/) - INDEX = 0 - GO TO 10 - END IF - call w3difdat(kdate,ndate,3,rinc) - kmin = rinc(3) - call w3difdat(ldate,ndate,3,rinc) - lmin = rinc(3) -C CHECK DATE OF MESSAGE AGAINST SPECIFIED TIME RANGES - if((kmin.gt.0.or.lmin.lt.0).AND.IREC.GT.2) then - PRINT 106, IREC,MDATE - 106 FORMAT(' BUFR MESSAGE NO.',I3,' WITH DATE:',I5,3I3,' 0 NOT W/I', - $ ' REQ. TIME RANGE, TRY READING NEXT MSG'/) - INDEX = 0 - GO TO 10 - END IF - END IF -C======================================================================= -C READ NEXT SUBSET (REPORT) IN MESSAGE - - IF(IPRINT.GT.1) PRINT *,'CALL READSB' - CALL READSB(LUNIT,JRET) - IF(IPRINT.GT.1) PRINT *,'BACK FROM READSB' - IF(JRET.NE.0) THEN - IF(INDEX.GT.0) THEN - -C ALL SUBSETS IN THIS MESSAGE PROCESSED, READ IN NEXT MESSAGE (IF ALL -C MESSAGES READ IN NO MORE DATA TO PROCESS) - - IF(IPRINT.GT.1) PRINT *, 'ALL REPORTS IN THIS MESSAGE ', - $ 'DECODED, GO ON TO NEXT MESSAGE' - ELSE - -C THERE WERE NO SUBSETS FOUND IN THIS BUFR MESSAGE, GOOD CHANCE IT IS -C ONE OF TWO DUMMY MESSAGES AT TOP OF FILE INDICATING CENTER TIME AND -C DATA DUMP TIME ONLY; READ IN NEXT MESSAGE - - IF(IREC.EQ.1) THEN - PRINT 4567, ICDATE - 4567 FORMAT(/'===> BUFR MESSAGE NO. 1 IS A DUMMY MESSAGE CONTAINING ', - $ 'ONLY CENTER DATE (',I5,4I3,') - NO DATA - GO ON TO NEXT ', - $ 'MESSAGE'/) - ELSE IF(IREC.EQ.2) THEN - PRINT 4568, IDDATE - 4568 FORMAT(/'===> BUFR MESSAGE NO. 2 IS A DUMMY MESSAGE CONTAINING ', - $ 'ONLY DUMP DATE (',I5,4I3,') - NO DATA - GO ON TO NEXT ', - $ 'MESSAGE'/) - ELSE - PRINT 4569, IREC,MDATE - 4569 FORMAT(/'===> BUFR MESSAGE NO.',I3,' (DATE:',I5,3I3,' 0) ', - $ 'CONTAINS ZERO REPORTS FOR SOME UNEXPLAINED REASON - GO ON TO ', - $ 'NEXT MESSAGE'/) - END IF - END IF - INDEX = 0 - GO TO 10 - END IF -C----------------------------------------------------------------------- - IF(IPRINT.GT.1) PRINT *, 'READY TO PROCESS NEW DECODED REPORT' -C*********************************************************************** -C A SINGLE REPORT HAS BEEN SUCCESSFULLY DECODED -C*********************************************************************** - INDEX = INDEX + 1 - IF(IPRINT.GE.1) PRINT *, 'WORKING WITH SUBSET NUMBER ',INDEX - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7702 INITIALIZES THE OUTPUT ARRAY FOR A REPORT -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 1996-12-16 -C -C ABSTRACT: INITIALIZES THE OUTPUT ARRAY WHICH HOLDS A SINGLE REPORT -C IN THE QUASI-OFFICE NOTE 29 UNPACKED FORMAT TO ALL MISSING. -C -C PROGRAM HISTORY LOG: -C 1996-12-16 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C -C USAGE: CALL UNPK7702(RDATA,ITP) -C INPUT ARGUMENT LIST: -C ITP - THE TYPE OF REPORT THAT HAS BEEN DECODED {=1 - -C - WIND PROFILER, =2 - GOES SNDG, =3 - NEXRAD(VAD) WIND} -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE REPORT RETURNED AN A QUASI-OFFICE NOTE 29 -C UNPACKED FORMAT; ALL DATA ARE MISSING -C -C REMARKS: CALLED BY SUBROUTINE W3UNPK77. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7702(RDATA,ITP) - REAL RDATA(*),RDATX(1200) - INTEGER IDATA(1200),IRTYP(3) - CHARACTER*8 COB -C - SAVE -C - EQUIVALENCE (RDATX,IDATA),(COB,IOB) - DATA XMSG/99999./,IMSG/99999/,IRTYP/71,61,72/ - RDATX(1) = XMSG - RDATX(2) = XMSG - IDATA(3) = IMSG - RDATX(4) = XMSG - COB = '999999 ' - IDATA(5) = IOB - COB = '9999 ' - IDATA(6) = IOB - RDATX(7) = XMSG - IDATA(8) = IMSG - IDATA(9) = IRTYP(ITP) - IDATA(10) = IMSG - COB = ' ' - IDATA(11) = IOB - IDATA(12) = IOB -C -C ALL TYPES -- LOAD ZEROS INTO THE DEFINING WORD PAIRS -C - IDATA(13:42) = 0 -C -C ALL TYPES -- LOAD MISSINGS INTO THE DATA PORTION -C - RDATX(43:1200) = XMSG - IF(ITP.EQ.1) THEN -C -C PROFILER -- LOAD INTEGER MISSING WHERE APPROPRIATE -C (Current limit of 104 Cat. 11 levels) -C - IDATA(53:1200:11) = IMSG - IDATA(55:1200:11) = IMSG - IDATA(56:1200:11) = IMSG - IDATA(60:1200:11) = IMSG - ELSE IF(ITP.EQ.2) THEN -C -C GOES -- LOAD DEFAULT OF BLANK CHARACTERS INTO CAT. 12 -C LEVEL QUALITY MARKERS -C (Current limit of 50 Cat. 12 levels) -C (could be expanded if need be) -C - IDATA(49:392:7) = IOB -C -C GOES -- LOAD DEFAULT OF BLANK CHARACTER INTO FIRST CAT. 08 -C LEVEL QUALITY MARKER -C (Current limit of 9 Cat. 08 levels) -C (could be expanded if need be) -C - IDATA(395:419:3) = IOB -C GOES -- LOAD INTEGER MISSING INTO CAT. 13 LEVEL CHANNEL NUMBER -C -- LOAD DEFAULT OF BLANK CHARACTER INTO CAT. 13 LEVEL -C QUALITY MARKER -C (Current limit of 60 Cat. 13 levels) -C (could be expanded if need be) -C - IDATA(420:599:3) = IMSG - IDATA(422:599:3) = IOB - ELSE IF(ITP.EQ.3) THEN -C -C VADWND -- LOAD DEFAULT OF BLANK CHARACTER INTO HGHT CAT. 04 -C LEVEL QUALITY MARKER -C (Current limit of 70 Cat. 04 levels) -C (could be expanded if need be) -C - IDATA(46:1200:4) = IOB - END IF - RDATA(1:1200) = RDATX(1:1200) - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7703 FILLS IN HEADER IN O-PUT ARRAY - PFLR RPT -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 2002-03-05 -C -C ABSTRACT: FOR REPORT (SUBSET) READ OUT OF BUFR MESSAGE (PASSED IN -C INTERNALLY VIA BUFRLIB STORAGE), CALLS BUFRLIB ROUTINE TO DECODE -C HEADER DATA FOR WIND PROFILER REPORT. HEADER IS THEN FILLED INTO -C THE OUTPUT ARRAY WHICH HOLDS A SINGLE WIND PROFILER REPORT IN THE -C QUASI-OFFICE NOTE 29 UNPACKED FORMAT. -C -C PROGRAM HISTORY LOG: -C 1996-12-16 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C 2002-03-05 KEYSER -- ACCOUNTS FOR CHANGES IN INPUT PROFLR (WIND -C PROFILER) BUFR DUMP FILE AFTER 3/2002: MNEMONIC -C "NPSM" IS NO LONGER AVAILABLE, MNEMONIC "TPSE" -C REPLACES "TPMI" (AVG. TIME IN MINUTES STILL -C OUTPUT) (WILL STILL WORK PROPERLY FOR INPUT -C PROFLR DUMP FILES PRIOR TO 3/2002) -C -C USAGE: CALL UNPK7703(LUNIT,RDATA,IRET) -C INPUT ARGUMENT LIST: -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C RDATA - SINGLE WIND PROFILER REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH ALL DATA INITIALIZED AS MISSING -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE WIND PROFILER REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH HEADER INFORMATION FILLED IN -C - (ALL OTHER DATA REMAINS MISSING) -C IRET - RETURN CODE AS DESCRIBED IN W3UNPK77 DOCBLOCK -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBROUTINE W3UNPK77. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7703(LUNIT,RDATA,IRET) - CHARACTER*6 STNID - CHARACTER*8 COB - CHARACTER*35 HDR1,HDR2 - INTEGER IDATA(1200) - REAL(8) HDR_8(16) - REAL HDR(16),RDATA(*),RDATX(1200) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - - SAVE - - EQUIVALENCE (RDATX,IDATA),(COB,IOB) - DATA XMSG/99999./,IMSG/99999/ - DATA HDR1/'CLAT CLON TSIG SELV NPSM TPSE WMOB '/ - DATA HDR2/'WMOS YEAR MNTH DAYS HOUR MINU TPMI '/ - RDATX(1:1200) = RDATA(1:1200) - HDR_8 = 10.0E10 - CALL UFBINT(LUNIT,HDR_8,16,1,NLEV,HDR1//HDR2);HDR=HDR_8 - IF(NLEV.NE.1) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS NOT WHAT IS EXPECTED -- -C SET IRET = 6 AND RETURN - PRINT 217, NLEV - 217 FORMAT(/' ##W3UNPK77: THE NUMBER OF DECODED "LEVELS" (=',I5,') ', - $ 'IS NOT WHAT IS EXPECTED (1) - IRET = 6'/) - IRET = 6 - RETURN -C....................................................................... - END IF - -C LATITUDE (STORED AS REAL) - - M = 1 - IF(IPRINT.GT.1) PRINT 199, HDR(1),M - 199 FORMAT(5X,'HDR HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF(HDR(1).LT.XMSG) THEN - RDATX(1) = NINT(HDR(1) * 100.) - NNNNN = 1 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - 198 FORMAT(5X,'DATA(',I5,') STORED AS: ',F10.2) - ELSE - IRET = 2 - PRINT 102 - 102 FORMAT(' *** W3UNPK77 ERROR: LAT MISSING FOR WIND PROFILER ', - $ 'REPORT'/) - RETURN - END IF - -C LONGITUDE (STORED AS REAL) - - M = 2 - IF(IPRINT.GT.1) PRINT 199, HDR(2),M - IF(HDR(2).LT.XMSG) THEN - RDATX(2) = NINT(MOD((36000.-(HDR(2)*100.)),36000.)) - NNNNN = 2 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - ELSE - IRET = 2 - PRINT 104 - 104 FORMAT(' *** W3UNPK77 ERROR: LON MISSING FOR WIND PROFILER ', - $ 'REPORT'/) - RETURN - END IF - -C TIME SIGNIFICANCE (STORED AS INTEGER) - - M = 3 - IF(IPRINT.GT.1) PRINT 199, HDR(3),M - IF(HDR(3).LT.XMSG) IDATA(3) = NINT(HDR(3)) - NNNNN = 3 - IF(IPRINT.GT.1) PRINT 197, NNNNN,IDATA(NNNNN) - 197 FORMAT(5X,'IDATA(',I5,') STORED AS: ',I10) - -C STATION ELEVATION (FROM REPORTED STN. HGHT; STORED IN OUTPUT) -C (STORED AS REAL) - - M = 4 - IF(IPRINT.GT.1) PRINT 199, HDR(4),M - IF(HDR(4).LT.XMSG) RDATX(7) = NINT(HDR(4)) - NNNNN = 7 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - -C SUBMODE INFORMATION -C EDITION NUMBER (ALWAYS = 2) -C (PACKED AS SUBMODE TIMES 10 PLUS EDITION NUMBER - INTEGER) -C {NOTE: After 3/2002, the submode information is no longer -C available and is stored as missing (3).} - - M = 5 - IEDTN = 2 - IDATA(8) = (3 * 10) + IEDTN - IF(IPRINT.GT.1) PRINT 199, HDR(5),M - IF(HDR(5).LT.XMSG) IDATA(8) = (NINT(HDR(5)) * 10) + IEDTN - NNNNN = 8 - IF(IPRINT.GT.1) PRINT 197, NNNNN,IDATA(NNNNN) - -C AVERAGING TIME (STORED AS INTEGER) -C (NOTE: Prior to 3/2002, this is decoded in minutes, after -C 3/2002 this is decoded in seconds - in either case -C it is stored in minutes) - - M = 6 - IF(IPRINT.GT.1) PRINT 199, HDR(6),M - IF(IPRINT.GT.1) PRINT 199, HDR(14),M - IF(HDR(6).LT.XMSG) THEN - IDATA(10) = NINT(HDR(6)/60.) - ELSE IF(HDR(14).LT.XMSG) THEN - IDATA(10) = NINT(HDR(14)) - END IF - NNNNN = 10 - IF(IPRINT.GT.1) PRINT 197, NNNNN,IDATA(NNNNN) -C----------------------------------------------------------------------- - -C STATION IDENTIFICATION (STORED AS CHARACTER) -C (OBTAINED FROM ENCODED WMO BLOCK/STN NUMBERS) - - STNID = ' ' - -C WMO BLOCK NUMBER (STORED AS CHARACTER) - - M = 7 - IF(IPRINT.GT.1) PRINT 199, HDR(7),M - IF(HDR(7).LT.XMSG) WRITE(STNID(1:2),'(I2.2)') NINT(HDR(7)) - -C WMO STATION NUMBER (STORED AS CHARACTER) - - M = 8 - IF(IPRINT.GT.1) PRINT 199, HDR(8),M - IF(HDR(8).LT.XMSG) WRITE(STNID(3:5),'(I3.3)') NINT(HDR(8)) - COB(1:4) = STNID(1:4) - IDATA(11) = IOB - NNNNN = 11 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - 196 FORMAT(5X,'IDATA(',I5,') STORED IN CHARACTER AS: "',A4,'"') - COB(1:4) = STNID(5:6)//' ' - IDATA(12) = IOB - NNNNN = 12 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - -cvvvvvdak port -C LOAD THE YEAR/MONTH (STORED AS CHARACTER IN FORM YYMM) -caaaaadak port - - M = 9 - IF(IPRINT.GT.1) PRINT 199, HDR(9),M - IYEAR = IMSG - IF(HDR(9).LT.XMSG) IYEAR = NINT(HDR(9)) - M = 10 - IF(IPRINT.GT.1) PRINT 199, HDR(10),M - IF(HDR(10).LT.XMSG.AND.IYEAR.LT.IMSG) THEN -cvvvvvdak port - IYEAR = MOD(IYEAR,100) -caaaaadak port - IYEAR = NINT(HDR(10)) + (IYEAR * 100) -cvvvvvdak port -cdak WRITE(COB,'(I6.6,2X)') IYEAR - WRITE(COB,'(I4.4,4X)') IYEAR -caaaaadak port - IDATA(5) = IOB - NNNNN = 5 - IF(IPRINT.GT.1) PRINT 9196, NNNNN,COB(1:6) - 9196 FORMAT(5X,'IDATA(',I5,') STORED IN CHARACTER AS: "',A6,'"') - ELSE - GO TO 30 - END IF - -C LOAD THE DAY/HOUR (STORED AS CHARACTER IN FORM DDHH) -C AND THE OBSERVATION TIME (STORED AS REAL) - - M = 11 - IF(IPRINT.GT.1) PRINT 199, HDR(11),M - IDAY = IMSG - IF(HDR(11).LT.XMSG) IDAY = NINT(HDR(11)) - M = 12 - IF(IPRINT.GT.1) PRINT 199, HDR(12),M - IF(HDR(12).LT.XMSG.AND.IDAY.LT.IMSG) THEN - IHRT = NINT(HDR(12)) - M = 13 - IF(IPRINT.GT.1) PRINT 199, HDR(13),M - IF(HDR(13).GE.XMSG) GO TO 30 - RMNT = HDR(13) - RDATX(4) = NINT((IHRT * 100.) + (RMNT * 100.)/60.) - NNNNN = 4 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - IHRT = IHRT + (IDAY * 100) - WRITE(COB(1:4),'(I4.4)') IHRT - IDATA(6) = IOB - NNNNN = 6 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - ELSE - GO TO 30 - END IF - RDATA(1:1200) = RDATX(1:1200) - RETURN - 30 CONTINUE - IRET = 4 - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7704 FILLS CAT.10 INTO O-PUT ARRAY - PFLR RPT -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 2002-03-05 -C -C ABSTRACT: FOR REPORT (SUBSET) READ OUT OF BUFR MESSAGE (PASSED IN -C INTERNALLY VIA BUFRLIB STORAGE), CALLS BUFRLIB ROUTINE TO DECODE -C SURFACE DATA FOR WIND PROFILER REPORT. SURFACE DATA ARE THEN -C FILLED INTO THE OUTPUT ARRAY AS CATEGORY 10. THE OUPUT ARRAY -C HOLDS A SINGLE WIND PROFILER REPORT IN THE QUASI-OFFICE NOTE 29 -C UNPACKED FORMAT. -C -C PROGRAM HISTORY LOG: -C 1996-12-16 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C 2002-03-05 KEYSER -- ACCOUNTS FOR CHANGES IN INPUT PROFLR (WIND -C PROFILER) BUFR DUMP FILE AFTER 3/2002: SURFACE -C DATA NOW ALL MISSING (MNEMONICS "PMSL", -C "WDIR1","WSPD1", "TMDB", "REHU", "REQV" NO -C LONGER AVAILABLE) (WILL STILL WORK PROPERLY FOR -C INPUT PROFLR DUMP FILES PRIOR TO 3/2002) -C -C USAGE: CALL UNPK7704(LUNIT,RDATA) -C INPUT ARGUMENT LIST: -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C RDATA - SINGLE WIND PROFILER REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH ONLY HEADER INFORMATION FILLED -C - IN (ALL OTHER DATA REMAINS MISSING) -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE WIND PROFILER REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH SURFACE INFORMATION FILLED IN -C - (AS WELL AS THE HEADER; ALL OTHER DATA REMAINS -C - MISSING) -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBROUTINE W3UNPKB7. AFTER 3/2002, THERE IS -C NO SURFACE DATA AVAILABLE. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7704(LUNIT,RDATA) - CHARACTER*40 SRFC - INTEGER IDATA(1200) - REAL(8) SFC_8(8) - REAL SFC(8),RDATA(*),RDATX(1200) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - - SAVE - - EQUIVALENCE (RDATX,IDATA) - DATA XMSG/99999./ - DATA SRFC/'PMSL WDIR1 WSPD1 TMDB REHU REQV '/ - RDATX(1:1200) = RDATA(1:1200) - SFC_8 = 10.0E10 - CALL UFBINT(LUNIT,SFC_8,8,1,NLEV,SRFC);SFC=SFC_8 - IF(NLEV.NE.1) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS NOT WHAT IS EXPECTED -- - PRINT 217, NLEV - 217 FORMAT(/' ##W3UNPK77: THE NUMBER OF DECODED "LEVELS" (=',I5,') ', - $ 'IS NOT WHAT IS EXPECTED (1) - NO SFC DATA PROCESSED'/) - GO TO 99 -C....................................................................... - END IF - -C MSL PRESSURE (STORED AS REAL) - - M = 1 - IF(IPRINT.GT.1) PRINT 199, SFC(1),M - 199 FORMAT(5X,'SFC HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF((SFC(1)*0.1).LT.XMSG) RDATX(43) = NINT(SFC(1) * 0.1) - NNNNN = 43 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(43) - 198 FORMAT(5X,'RDATA(',I5,') STORED AS: ',F10.2) - -C SURFACE HORIZONTAL WIND DIRECTION (STORED AS REAL) - - M = 2 - IF(IPRINT.GT.1) PRINT 199, SFC(2),M - IF(SFC(2).LT.XMSG) RDATX(43+2) = NINT(SFC(2)) - NNNNN = 43 + 2 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(43+2) - -C SURFACE HORIZONTAL WIND SPEED (STORED AS REAL) - - M = 3 - IF(IPRINT.GT.1) PRINT 199, SFC(3),M - IF(SFC(3).LT.XMSG) RDATX(43+3) = NINT(SFC(3) * 10.) - NNNNN = 43 + 3 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(43+3) - -C SURFACE TEMPERATURE (STORED AS REAL) - - M = 4 - IF(IPRINT.GT.1) PRINT 199, SFC(4),M - IF(SFC(4).LT.XMSG) RDATX(43+4) = NINT(SFC(4) * 10.) - NNNNN = 43 + 4 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(43+4) - -C RELATIVE HUMIDITY (STORED AS REAL) - - M = 5 - IF(IPRINT.GT.1) PRINT 199, SFC(5),M - IF(SFC(5).LT.XMSG) RDATX(43+5) = NINT(SFC(5)) - NNNNN = 43 + 5 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(43+5) - -C RAINFALL RATE (STORED AS REAL) - - M = 6 - IF(IPRINT.GT.1) PRINT 199, SFC(6),M - IF(SFC(6).LT.XMSG) RDATX(43+6) = NINT(SFC(6) * 1.E7) - NNNNN = 43 + 6 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(43+6) - -C SET CATEGORY COUNTERS FOR SURFACE DATA - - IDATA(35) = 1 - IDATA(36) = 43 - 99 CONTINUE - IF(IPRINT.GT.1) PRINT *, 'IDATA(35)=',IDATA(35),'; IDATA(36)=', - $ IDATA(36) - RDATA(1:1200) = RDATX(1:1200) - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7705 FILLS CAT.11 INTO O-PUT ARRAY - PFLR RPT -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 2002-03-05 -C -C ABSTRACT: FOR REPORT (SUBSET) READ OUT OF BUFR MESSAGE (PASSED IN -C INTERNALLY VIA BUFRLIB STORAGE), CALLS BUFRLIB ROUTINE TO DECODE -C UPPER-AIR DATA FOR WIND PROFILER REPORT. UPPER-AIR DATA ARE THEN -C FILLED INTO THE OUTPUT ARRAY AS CATEGORY 11. THE OUPUT ARRAY -C HOLDS A SINGLE WIND PROFILER REPORT IN THE QUASI-OFFICE NOTE 29 -C UNPACKED FORMAT. -C -C PROGRAM HISTORY LOG: -C 1996-12-16 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C 1998-07-09 KEYSER -- MODIFIED WIND PROFILER CAT. 11 (HEIGHT, HORIZ. -C SIGNIFICANCE, VERT. SIGNIFICANCE) PROCESSING -C TO ACCOUNT FOR UPDATES TO BUFRTABLE MNEMONICS -C IN /dcom -C 2002-03-05 KEYSER -- ACCOUNTS FOR CHANGES IN INPUT PROFLR (WIND -C PROFILER) BUFR DUMP FILE AFTER 3/2002: -C MNEMONICS "ACAVH", "ACAVV", "SPP0", AND "NPHL" -C NO LONGER AVAILABLE; (WILL STILL WORK PROPERLY -C FOR INPUT PROFLR DUMP FILES PRIOR TO 3/2002) -C -C USAGE: CALL UNPK7705(LUNIT,RDATA) -C INPUT ARGUMENT LIST: -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C RDATA - SINGLE WIND PROFILER REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH ONLY HEADER AND SURFACE -C - INFORMATION FILLED IN (UPPER-AIR DATA MISSING) -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE WIND PROFILER REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH UPPER-AIR INFORMATION FILLED -C - IN (ALL DATA FOR REPORT NOW FILLED) -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBROUTINE W3UNPK77. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7705(LUNIT,RDATA) - CHARACTER*31 UAIR1,UAIR2 - CHARACTER*16 UAIR3 - INTEGER IDATA(1200) - REAL(8) UAIR_8(16,255) - REAL UAIR(16,255),RDATA(*),RDATX(1200) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - - SAVE - - EQUIVALENCE (RDATX,IDATA) - DATA XMSG/99999./ - DATA UAIR1/'HEIT WDIR WSPD NPQC WCMP ACAVH '/ - DATA UAIR2/'ACAVV SPP0 SDHS SDVS NPHL '/ - DATA UAIR3/'HAST ACAV1 ACAV2'/ - RDATX(1:1200) = RDATA(1:1200) - NSFC = 0 - ILVL = 0 - ILC = 0 -C FIRST UPPER-AIR LEVEL IS THE SURFACE INFORMATION - IF(IPRINT.GT.1) PRINT 1078, ILC,ILVL - 1078 FORMAT(' ATTEMPTING 1ST (SFC) LVL WITH ILC =',I5,'; NO. LEVELS ', - $ 'PROCESSED TO NOW =',I5) - RDATX(50+ILC) = RDATX(7) - IF(IPRINT.GT.1) PRINT 198, 50+ILC,RDATX(50+ILC) - 198 FORMAT(5X,'RDATA(',I5,') STORED AS: ',F10.2) - IF(RDATX(50+ILC).LT.XMSG) NSFC = 1 - IF(IDATA(35).GE.1) THEN - RDATX(50+ILC+1) = RDATX(IDATA(36)+2) - RDATX(50+ILC+2) = RDATX(IDATA(36)+3) - END IF - IF(IPRINT.GT.1) PRINT 198, 50+ILC+1,RDATX(50+ILC+1) - IF(RDATX(50+ILC+1).LT.XMSG) NSFC = 1 - IF(IPRINT.GT.1) PRINT 198, 50+ILC+2,RDATX(50+ILC+2) - IF(RDATX(50+ILC+2).LT.XMSG) NSFC = 1 - ILVL = ILVL + 1 - ILC = ILC + 11 - IF(IPRINT.GT.1) PRINT *,'HAVE COMPLETED LEVEL ',ILVL,' WITH ', - $ 'NSFC=',NSFC,'; GOING INTO NEXT LEVEL WITH ILC=',ILC - UAIR_8 = 10.0E10 - CALL UFBINT(LUNIT,UAIR_8,16,255,NLEV,UAIR1//UAIR2//UAIR3) - UAIR=UAIR_8 - IF(NLEV.EQ.0) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS ZERO -- - IF(NSFC.EQ.0) THEN -C ... NO UPPER AIR DATA PROCESSED - PRINT 217 - 217 FORMAT(/' ##W3UNPK77: NO UPPER-AIR DATA PROCESSED FOR THIS', - $ ' REPORT -- NLEV = 0 AND NSFC = 0'/) - GO TO 99 - ELSE -C ... ONLY FIRST (SURFACE) UPPER AIR LEVEL DATA PROCESSED - PRINT 218 - 218 FORMAT(/' ##W3UNPK77: NO UPPER-AIR DATA ABOVE FIRST (SURFACE) ', - $ 'LEVEL PROCESSED FOR THIS REPORT -- NLEV = 0 AND NSFC > 0'/) - GO TO 98 - END IF -C....................................................................... - END IF - IF(IPRINT.GT.1) PRINT 1068, NLEV - 1068 FORMAT(' THIS REPORT CONTAINS ',I3,' LEVELS OF DATA (NOT ', - $ 'INCLUDING BOTTOM -SURFACE- LEVEL)') - DO I = 1,NLEV - IF(IPRINT.GT.1) PRINT 1079, ILC,ILVL - 1079 FORMAT(' ATTEMPTING NEW LEVEL WITH ILC =',I5,'; NO. LEVELS ', - $ 'PROCESSED TO NOW =',I5) - -C HEIGHT ABOVE SEA-LEVEL (STORED AS REAL) -C (NOTE: At one time, possibly even now, the height above sea -C level was erroneously stored under mnemonic "HAST" -C when it should have been stored under mnemonic "HEIT". -C ("HAST" is defined as the height above the station.) -C Will test first for valid data in "HEIT" - if missing, -C then will use data in "HAST" - this will allow this -C routine to transition w/o change when the fix is made.) - - IF(UAIR(1,I).LT.XMSG) THEN - M = 1 - IF(IPRINT.GT.1) PRINT 199, UAIR(1,I),M - 199 FORMAT(5X,'UAIR HERE IS: ',F17.4,'; INDEX IS: ',I3) - RDATX(50+ILC) = NINT(UAIR(1,I)) - ELSE - M = 12 - IF(IPRINT.GT.1) PRINT 199, UAIR(12,I),M - IF(UAIR(12,I).LT.XMSG) RDATX(50+ILC) = NINT(UAIR(12,I)) - END IF - IF(IPRINT.GT.1) PRINT 198, 50+ILC,RDATX(50+ILC) - ILVL = ILVL + 1 - -C HORIZONTAL WIND DIRECTION (STORED AS REAL) - - M = 2 - IF(IPRINT.GT.1) PRINT 199, UAIR(2,I),M - IF(UAIR(2,I).LT.XMSG) RDATX(50+ILC+1) = NINT(UAIR(2,I)) - IF(IPRINT.GT.1) PRINT 198, 50+ILC+1,RDATX(50+ILC+1) - -C HORIZONTAL WIND SPEED (STORED AS REAL) - - M = 3 - IF(IPRINT.GT.1) PRINT 199, UAIR(3,I),M - IF(UAIR(3,I).LT.XMSG) RDATX(50+ILC+2) =NINT(UAIR(3,I) * 10.) - IF(IPRINT.GT.1) PRINT 198, 50+ILC+2,RDATX(50+ILC+2) - -C QUALITY CODE (STORED AS INTEGER) - - M = 4 - IF(IPRINT.GT.1) PRINT 199, UAIR(4,I),M - IF(UAIR(4,I).LT.XMSG) IDATA(50+ILC+3) = NINT(UAIR(4,I)) - IF(IPRINT.GT.1) PRINT 197, 50+ILC+3,IDATA(50+ILC+3) - 197 FORMAT(5X,'IDATA(',I5,') STORED AS: ',I10) - -C VERTICAL WIND COMPONENT (W) (STORED AS REAL) - - M = 5 - IF(IPRINT.GT.1) PRINT 199, UAIR(5,I),M - IF(UAIR(5,I).LT.XMSG) RDATX(50+ILC+4) = NINT(UAIR(5,I) * 100.) - IF(IPRINT.GT.1) PRINT 198, 50+ILC+4,RDATX(50+ILC+4) - -C HORIZONTAL CONSENSUS NUMBER (STORED AS INTEGER) -C (NOTE: Prior to 2/18/1999, the horizonal consensus number was -C stored under mnemonic "ACAV1". -C From 2/18/1999 through 3/2002, the horizontal consensus -C number was stored under mnemonic "ACAVH". -C After 3/2002, the horizontal consensus number is no -C longer stored. -C Will test first for valid data in "ACAVH" - if missing, -C then will test for data in "ACAV1" - this will allow -C this routine to work properly with historical data.) - - IF(IPRINT.GT.1) PRINT 199, UAIR(6,I),M - IF(IPRINT.GT.1) PRINT 199, UAIR(13,I),M - IF(UAIR(6,I).LT.XMSG) THEN - M = 6 - IDATA(50+ILC+5) = NINT(UAIR(6,I)) - ELSE - M = 13 - IF(UAIR(13,I).LT.XMSG) IDATA(50+ILC+5) = NINT(UAIR(13,I)) - END IF - IF(IPRINT.GT.1) PRINT 197, 50+ILC+5,IDATA(50+ILC+5) - -C VERTICAL CONSENSUS NUMBER (STORED AS INTEGER) -C (NOTE: Prior to 2/18/1999, the vertical consensus number was -C stored under mnemonic "ACAV2". -C From 2/18/1999 through 3/2002, the vertical consensus -C number was stored under mnemonic "ACAVV". -C After 3/2002, the vertical consensus number is no -C longer stored. -C Will test first for valid data in "ACAVV" - if missing, -C then will test for data in "ACAV2" - this will allow -C this routine to work properly with historical data.) - - IF(IPRINT.GT.1) PRINT 199, UAIR(7,I),M - IF(IPRINT.GT.1) PRINT 199, UAIR(14,I),M - IF(UAIR(7,I).LT.XMSG) THEN - M = 7 - IDATA(50+ILC+6) = NINT(UAIR(7,I)) - ELSE - M = 14 - IF(UAIR(14,I).LT.XMSG) IDATA(50+ILC+6) = NINT(UAIR(14,I)) - END IF - IF(IPRINT.GT.1) PRINT 197, 50+ILC+6,IDATA(50+ILC+6) - -C SPECTRAL PEAK POWER (STORED AS REAL) -C (NOTE: After 3/2002, the spectral peak power is no longer -C stored.) - - M = 8 - IF(IPRINT.GT.1) PRINT 199, UAIR(8,I),M - IF(UAIR(8,I).LT.XMSG) RDATX(50+ILC+7) = NINT(UAIR(8,I)) - IF(IPRINT.GT.1) PRINT 198, 50+ILC+7,RDATX(50+ILC+7) - -C HORIZONTAL WIND SPEED STANDARD DEVIATION (STORED AS REAL) - - M = 9 - IF(IPRINT.GT.1) PRINT 199, UAIR(9,I),M - IF(UAIR(9,I).LT.XMSG) RDATX(50+ILC+8)=NINT(UAIR(9,I) * 10.) - IF(IPRINT.GT.1) PRINT 198, 50+ILC+8,RDATX(50+ILC+8) - -C VERTICAL WIND COMPONENT STANDARD DEVIATION (STORED AS REAL) - - M = 10 - IF(IPRINT.GT.1) PRINT 199, UAIR(10,I),M - IF(UAIR(10,I).LT.XMSG) RDATX(50+ILC+9) =NINT(UAIR(10,I) * 10.) - IF(IPRINT.GT.1) PRINT 198, 50+ILC+9,RDATX(50+ILC+9) - -C MODE INFORMATION (STORED AS INTEGER) -C (NOTE: After 3/2002, the mode information is no longer stored.) - - M = 11 - IF(IPRINT.GT.1) PRINT 199, UAIR(11,I),M - IF(UAIR(11,I).LT.XMSG) IDATA(50+ILC+10) = NINT(UAIR(11,I)) - IF(IPRINT.GT.1) PRINT 197, 50+ILC+10,IDATA(50+ILC+10) -C....................................................................... - ILC = ILC + 11 - IF(IPRINT.GT.1) PRINT *,'HAVE COMPLETED LEVEL ',ILVL, - $ '; GOING INTO NEXT LEVEL WITH ILC=',ILC - ENDDO - -C SET CATEGORY COUNTERS FOR UPPER-AIR DATA - - 98 CONTINUE - IDATA(37) = ILVL - IDATA(38) = 50 - 99 CONTINUE - IF(IPRINT.GT.1) PRINT *, 'NSFC=',NSFC,'; IDATA(37)=',IDATA(37), - $ '; IDATA(38)=',IDATA(38) - RDATA(1:1200) = RDATX(1:1200) - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7706 FILLS IN HEADER IN O-PUT ARRAY - VADW RPT -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 1997-06-02 -C -C ABSTRACT: FOR REPORT (SUBSET) READ OUT OF BUFR MESSAGE (PASSED IN -C INTERNALLY VIA BUFRLIB STORAGE), CALLS BUFRLIB ROUTINE TO DECODE -C HEADER DATA FOR NEXRAD (VAD) WIND REPORT. HEADER IS THEN FILLED -C INTO THE OUTPUT ARRAY WHICH HOLDS A SINGLE VAD WIND REPORT IN THE -C QUASI-OFFICE NOTE 29 UNPACKED FORMAT. -C -C PROGRAM HISTORY LOG: -C 1997-06-02 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C -C USAGE: CALL UNPK7706(LUNIT,RDATA,IRET) -C INPUT ARGUMENT LIST: -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C RDATA - SINGLE NEXRAD (VAD) REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH ALL DATA INITIALIZED AS MISSING -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE NEXRAD (VAD) REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH HEADER INFORMATION FILLED IN -C - (ALL OTHER DATA REMAINS MISSING) -C IRET - RETURN CODE AS DESCRIBED IN W3UNPK77 DOCBLOCK -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBROUTINE W3UNPK77. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7706(LUNIT,RDATA,IRET) - CHARACTER*8 STNID,COB - CHARACTER*45 HDR1 - INTEGER IDATA(1200) - REAL(8) HDR_8(9) - REAL HDR(9),RDATA(*),RDATX(1200) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - - SAVE - - EQUIVALENCE (RDATX,IDATA),(STNID,HDR_8(4)),(COB,IOB) - DATA XMSG/99999./,IMSG/99999/ - DATA HDR1/'CLAT CLON SELV RPID YEAR MNTH DAYS HOUR MINU '/ - RDATX(1:1200) = RDATA(1:1200) - HDR_8 = 10.0E10 - CALL UFBINT(LUNIT,HDR_8,9,1,NLEV,HDR1);HDR=HDR_8 - IF(NLEV.NE.1) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS NOT WHAT IS EXPECTED -- -C SET IRET = 6 AND RETURN - PRINT 217, NLEV - 217 FORMAT(/' ##W3UNPK77: THE NUMBER OF DECODED "LEVELS" (=',I5,') ', - $ 'IS NOT WHAT IS EXPECTED (1) - IRET = 6'/) - IRET = 6 - RETURN -C....................................................................... - END IF - -C LATITUDE (STORED AS REAL) - - M = 1 - IF(IPRINT.GT.1) PRINT 199, HDR(1),M - 199 FORMAT(5X,'HDR HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF(HDR(1).LT.XMSG) THEN - RDATX(1) = NINT(HDR(1) * 100.) - NNNNN = 1 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - 198 FORMAT(5X,'RDATA(',I5,') STORED AS: ',F10.2) - ELSE - IRET = 2 - PRINT 102 - 102 FORMAT(' *** W3UNPK77 ERROR: LAT MISSING FOR VAD WIND REPORT'/) - RETURN - END IF - -C LONGITUDE (STORED AS REAL) - - M = 2 - IF(IPRINT.GT.1) PRINT 199, HDR(2),M - IF(HDR(2).LT.XMSG) THEN - RDATX(2) = NINT(MOD((36000.-(HDR(2)*100.)),36000.)) - NNNNN = 2 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - ELSE - IRET = 2 - PRINT 104 - 104 FORMAT(' *** W3UNPK77 ERROR: LON MISSING FOR VAD WIND REPORT'/) - RETURN - END IF - -C STATION ELEVATION (FROM REPORTED STN. HGHT; STORED IN OUTPUT) -C (STORED AS REAL) - - M = 3 - IF(IPRINT.GT.1) PRINT 199, HDR(3),M - IF(HDR(3).LT.XMSG) RDATX(7) = NINT(HDR(3)) - NNNNN = 7 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - -C STATION IDENTIFICATION (STORED AS CHARACTER) -C ('99'//LAST 3-CHARACTERS OF PRODUCT SOURCE ID//' ') - - M = 4 - IF(IPRINT.GT.1) PRINT 299, STNID,M - 299 FORMAT(5X,'HDR HERE IS: ',9X,A8,'; INDEX IS: ',I3) - COB(1:4) = '99'//STNID(2:3) - IDATA(11) = IOB - NNNNN = 11 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - 196 FORMAT(5X,'IDATA(',I5,') STORED IN CHARACTER AS: "',A4,'"') - COB(1:4) = STNID(4:4)//' ' - IDATA(12) = IOB - NNNNN = 12 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - -cvvvvvdak port -C LOAD THE YEAR/MONTH (STORED AS CHARACTER IN FORM YYMM) -caaaaadak port - - M = 5 - IF(IPRINT.GT.1) PRINT 199, HDR(5),M - IYEAR = IMSG - IF(HDR(5).LT.XMSG) IYEAR = NINT(HDR(5)) - M = 6 - IF(IPRINT.GT.1) PRINT 199, HDR(6),M - IF(HDR(6).LT.XMSG.AND.IYEAR.LT.IMSG) THEN -cvvvvvdak port - IYEAR = MOD(IYEAR,100) -caaaaadak port - IYEAR = NINT(HDR(6)) + (IYEAR * 100) -cvvvvvdak port -cdak WRITE(COB,'(I6.6,2X)') IYEAR - WRITE(COB,'(I4.4,4X)') IYEAR -caaaaadak port - IDATA(5) = IOB - NNNNN = 5 - IF(IPRINT.GT.1) PRINT 9196, NNNNN,COB(1:6) - 9196 FORMAT(5X,'IDATA(',I5,') STORED IN CHARACTER AS: "',A6,'"') - ELSE - GO TO 30 - END IF - -C LOAD THE DAY/HOUR (STORED AS CHARACTER IN FORM DDHH) -C AND THE OBSERVATION TIME (STORED AS REAL) - - M = 7 - IF(IPRINT.GT.1) PRINT 199, HDR(7),M - IDAY = IMSG - IF(HDR(7).LT.XMSG) IDAY = NINT(HDR(7)) - M = 8 - IF(IPRINT.GT.1) PRINT 199, HDR(8),M - IF(HDR(8).LT.XMSG.AND.IDAY.LT.IMSG) THEN - IHRT = NINT(HDR(8)) - M = 9 - IF(IPRINT.GT.1) PRINT 199, HDR(9),M - IF(HDR(9).GE.XMSG) GO TO 30 - RMNT = HDR(9) - RDATX(4) = NINT((IHRT * 100.) + (RMNT * 100.)/60.) - NNNNN = 4 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - IHRT = IHRT + (IDAY * 100) - WRITE(COB(1:4),'(I4.4)') IHRT - IDATA(6) = IOB - NNNNN = 6 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - ELSE - GO TO 30 - END IF - RDATA(1:1200) = RDATX(1:1200) - RETURN - 30 CONTINUE - IRET = 4 - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7707 FILLS CAT. 4 INTO O-PUT ARRAY - VADW RPT -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 1997-06-02 -C -C ABSTRACT: FOR REPORT (SUBSET) READ OUT OF BUFR MESSAGE (PASSED IN -C INTERNALLY VIA BUFRLIB STORAGE), CALLS BUFRLIB ROUTINE TO DECODE -C UPPER-AIR DATA FOR NEXRAD (VAD) WIND REPORT. UPPER-AIR DATA ARE -C THEN FILLED INTO THE OUTPUT ARRAY AS CATEGORY 4. THE OUPUT ARRAY -C HOLDS A SINGLE VAD WIND REPORT IN THE QUASI-OFFICE NOTE 29 -C UNPACKED FORMAT. -C -C PROGRAM HISTORY LOG: -C 1997-06-02 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C -C USAGE: CALL UNPK7707(LUNIT,RDATA,IRET) -C INPUT ARGUMENT LIST: -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C RDATA - SINGLE NEXRAD (VAD) REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH ONLY HEADER INFORMATION FILLED -C - IN (CATEGORY 4 DATA MISSING) -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE NEXRAD (VAD) REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH CATEGORY 4 INFORMATION FILLED IN -C - (ALL DATA FOR REPORT NOW FILLED) -C IRET - RETURN CODE AS DESCRIBED IN W3UNPK77 DOCBLOCK -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBROUTINE W3UNPK77. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7707(LUNIT,RDATA,IRET) - CHARACTER*1 CRMS(0:12) - CHARACTER*8 COB - CHARACTER*25 UAIR1 - INTEGER IDATA(1200) - REAL(8) UAIR_8(5,255) - REAL UAIR(5,255),RDATA(*),RDATX(1200) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - - SAVE - - EQUIVALENCE (RDATX,IDATA),(COB,IOB) - DATA XMSG/99999./ - DATA UAIR1/'HEIT WDIR WSPD RMSW QMWN '/ - DATA CRMS/' ','A',' ','B',' ','C',' ','D',' ','E',' ','F',' '/ - RDATX(1:1200) = RDATA(1:1200) - NSFC = 0 - ILVL = 0 - ILC = 0 -C FIRST CATEGORY 4 LEVEL UPPER-AIR LEVEL CONTAINS ONLY HEIGHT (ELEV) - IF(IPRINT.GT.1) PRINT 1078, ILC,ILVL - 1078 FORMAT(' ATTEMPTING 1ST (SFC) LVL WITH ILC =',I5,'; NO. LEVELS ', - $ 'PROCESSED TO NOW =',I5) - RDATX(43+ILC) = RDATX(7) - IF(IPRINT.GT.1) PRINT 198, 43+ILC,RDATX(43+ILC) - 198 FORMAT(5X,'RDATA(',I5,') STORED AS: ',F10.2) - IF(RDATX(43+ILC).LT.XMSG) NSFC = 1 -C NOTE: The following was added because of a problem on the sgi-ha -C platform related to equivalencing character and non-character -C -- for now the addition of these two lines will set the quality -C mark for sfc. cat . 4 level to the correct value of " " -C rather than to "9999" - Mary McCann notified SGI of this -C problem on 08-21-1998 - cob = ' ' - idata(43+ilc+3) = iob - ILVL = ILVL + 1 - ILC = ILC + 4 - IF(IPRINT.GT.1) PRINT *,'HAVE COMPLETED LEVEL ',ILVL,' WITH ', - $ 'NSFC=',NSFC,'; GOING INTO NEXT LEVEL WITH ILC=',ILC - UAIR_8 = 10.0E10 - CALL UFBINT(LUNIT,UAIR_8,5,255,NLEV,UAIR1);UAIR=UAIR_8 - IF(NLEV.EQ.0) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS ZERO -- - IF(NSFC.EQ.0) THEN -C ... NO UPPER AIR DATA PROCESSED - PRINT 217 - 217 FORMAT(/' ##W3UNPK77: NO UPPER-AIR DATA PROCESSED FOR THIS', - $ ' REPORT -- NLEV = 0 AND NSFC = 0'/) - GO TO 99 - ELSE -C ... ONLY FIRST (SURFACE) UPPER AIR LEVEL DATA PROCESSED - PRINT 218 - 218 FORMAT(/' ##W3UNPK77: NO UPPER-AIR DATA ABOVE FIRST (SURFACE) ', - $ 'LEVEL PROCESSED FOR THIS REPORT -- NLEV = 0 AND NSFC > 0'/) - GO TO 98 - END IF -C....................................................................... - END IF - IF(IPRINT.GT.1) PRINT 1068, NLEV - 1068 FORMAT(' THIS REPORT CONTAINS ',I3,' LEVELS OF DATA (NOT ', - $ 'INCLUDING BOTTOM -SURFACE- LEVEL)') - DO I = 1,NLEV - IF(IPRINT.GT.1) PRINT 1079, ILC,ILVL - 1079 FORMAT(' ATTEMPTING NEW LEVEL WITH ILC =',I5,'; NO. LEVELS ', - $ 'PROCESSED TO NOW =',I5) - -C HEIGHT ABOVE SEA-LEVEL (STORED AS REAL) - - M = 1 - IF(IPRINT.GT.1) PRINT 199, UAIR(1,I),M - 199 FORMAT(5X,'UAIR HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF(UAIR(1,I).LT.XMSG) THEN - RDATX(43+ILC) = NINT(UAIR(1,I)) - -C ... WE HAVE A VALID CATEGORY 4 LEVEL -- THERE IS A VALID HEIGHT - - ILVL = ILVL + 1 - ELSE - -C ... WE DO NOT HAVE A VALID CATEGORY 4 LEVEL -- THERE IS NO VALID -C HEIGHT GO ON TO NEXT INPUT LEVEL - - IF(IPRINT.GT.1) PRINT *, 'HEIGHT MISSING ON INPUT ', - $ ' LEVEL ',I,', ALL OTHER DATA SET TO MSG ON THIS LEVEL' - GO TO 10 - END IF - IF(IPRINT.GT.1) PRINT 198, 43+ILC,RDATX(43+ILC) - -C HORIZONTAL WIND DIRECTION (STORED AS REAL) - - M = 2 - IF(IPRINT.GT.1) PRINT 199, UAIR(2,I),M - IF(UAIR(2,I).LT.XMSG) RDATX(43+ILC+1) = NINT(UAIR(2,I)) - IF(IPRINT.GT.1) PRINT 198, 43+ILC+1,RDATX(43+ILC+1) - -C HORIZONTAL WIND SPEED (STORED AS REAL) (OUTPUT STORED -C AS METERS/SECOND TIMES TEN, NOT IN KNOTS AS ON29 WOULD -C INDICATE FOR CAT. 4 WIND SPEED) - - M = 3 - IF(IPRINT.GT.1) PRINT 199, UAIR(3,I),M - IF(UAIR(3,I).LT.XMSG) RDATX(43+ILC+2) =NINT(UAIR(3,I) * 10.) - IF(IPRINT.GT.1) PRINT 198, 43+ILC+2,RDATX(43+ILC+2) - -C CONFIDENCE LEVEL (BASED ON RMS VECTOR WIND ERROR) -C (NOTE: CONVERTED TO ORIGINAL LETTER INDICATOR AND PACKED -C IN BYTE 4 OF CATEGORY 4 QUALITY MARKER LOCATION -- SEE -C W3UNPK77 DOCBLOCK REMARKS 5. FOR UNPACKED VAD WIND REPORT -C LAYOUT FOR VALUES - - M = 4 - IF(IPRINT.GT.1) PRINT 199, UAIR(4,I),M - IF(UAIR(4,I).LT.XMSG) THEN - -C ... CONVERT FROM M/S TO KNOTS - -CDAKCDAK KRMS = INT(1.93333 * UAIR(4,I)) - KRMS = INT(1.9425 * UAIR(4,I)) - COB = ' ' - IF(KRMS.LT.13) THEN - COB(4:4) = CRMS(KRMS) - ELSE - COB(4:4) = 'G' - END IF - IDATA(43+ILC+3) = IOB - END IF - IF(IPRINT.GT.1) PRINT 196, 43+ILC+3,COB(1:4) - 196 FORMAT(5X,'IDATA(',I5,') STORED IN CHARACTER AS: "',A4,'"') - -C ON29 WIND QUALITY MARKER (CURRENTLY NOT STORED) - - M = 5 - IF(IPRINT.GT.1) PRINT 199, UAIR(5,I),M -C....................................................................... - ILC = ILC + 4 - IF(IPRINT.GT.1) PRINT *,'HAVE COMPLETED LEVEL ',ILVL, - $ '; GOING INTO NEXT LEVEL WITH ILC=',ILC - - 10 CONTINUE - ENDDO - -C SET CATEGORY COUNTERS FOR UPPER-AIR DATA - - 98 CONTINUE - IDATA(19) = ILVL - 99 CONTINUE - IF(IDATA(19).EQ.0) THEN - IDATA(20) = 0 - IRET = 5 - ELSE - IDATA(20) = 43 - END IF - IF(IPRINT.GT.1) PRINT *, 'NSFC=',NSFC,'; IDATA(37)=',IDATA(37), - $ '; IDATA(38)=',IDATA(38) - RDATA(1:1200) = RDATX(1:1200) - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7708 FILLS IN HEADER IN O-PUT ARRAY - GOES SND -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 1998-07-09 -C -C ABSTRACT: FOR REPORT (SUBSET) READ OUT OF BUFR MESSAGE (PASSED IN -C INTERNALLY VIA BUFRLIB STORAGE), CALLS BUFRLIB ROUTINE TO DECODE -C HEADER DATA FOR GOES SOUNDING REPORT. HEADER IS THEN FILLED INTO -C THE OUTPUT ARRAY WHICH HOLDS A SINGLE GOES SOUNDING REPORT IN THE -C QUASI-OFFICE NOTE 29 UNPACKED FORMAT. -C -C PROGRAM HISTORY LOG: -C 1997-06-05 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C 1998-07-09 KEYSER -- CHANGED CHAR. 6 OF GOES STNID TO BE UNIQUE FOR -C TWO DIFFERENT EVEN OR ODD SATELLITE ID'S -C (EVERY OTHER EVEN OR ODD SAT. ID NOW GETS SAME -C CHAR. 6 TAG) -C -C USAGE: CALL UNPK7708(LUNIT,RDATA,KOUNT,IRET) -C INPUT ARGUMENT LIST: -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C RDATA - SINGLE GOES SNDG REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH ALL DATA INITIALIZED AS MISSING -C KOUNT - NUMBER OF REPORTS PROCESSED INCLUDING THIS ONE -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE GOES SNDG REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH HEADER INFORMATION FILLED IN -C - (ALL OTHER DATA REMAINS MISSING) -C IRET - RETURN CODE AS DESCRIBED IN W3UNPK77 DOCBLOCK -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBROUTINE W3UNPK77. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7708(LUNIT,RDATA,KOUNT,IRET) - CHARACTER*1 C6TAG(3,0:3) - CHARACTER*8 STNID,COB - CHARACTER*35 HDR1,HDR2 - INTEGER IDATA(1200) - REAL(8) HDR_8(12) - REAL HDR(12),RDATA(*),RDATX(1200) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - COMMON /PK77FF/IFOV(3),KNTSAT(250:260) - - SAVE - - EQUIVALENCE (RDATX,IDATA),(COB,IOB) - DATA XMSG/99999./,IMSG/99999/ - DATA HDR1/'CLAT CLON ACAV GSDP QMRK SAID YEAR '/ - DATA HDR2/'MNTH DAYS HOUR MINU SECO '/ - - -C CURRENT LIST OF SATELLITE IDENTIFIERS (BUFR C.F. 0-01-007) -C ----------------------------------------------------------- - -C GOES 6 -- 250 GOES 9 -- 253 GOES 12 -- 256 -C GOES 7 -- 251 GOES 10 -- 254 GOES 13 -- 257 -C GOES 8 -- 252 GOES 11 -- 255 GOES 14 -- 258 - -C IDSAT = -- EVEN1 -- --- ODD1 -- -- EVEN2 -- --- ODD2 -- -C Sat. No. - 252,256,... 253,257,... 250,254,... 251,255,... -C IRTYP = CLR COR UNKN CLR COR UNKN CLR COR UNKN CLR COR UNKN -C --- --- ---- --- --- ---- --- --- ---- --- --- ---- - - DATA C6TAG/'I','J','?', 'L','M','?', 'O','P','?', 'Q','R','?' / - - RDATX(1:1200) = RDATA(1:1200) - HDR_8 = 10.0E10 - CALL UFBINT(LUNIT,HDR_8,12,1,NLEV,HDR1//HDR2);HDR=HDR_8 - IF(NLEV.NE.1) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS NOT WHAT IS EXPECTED -- -C SET IRET = 6 AND RETURN - PRINT 217, NLEV - 217 FORMAT(/' ##W3UNPK77: THE NUMBER OF DECODED "LEVELS" (=',I5,') ', - $ 'IS NOT WHAT IS EXPECTED (1) - IRET = 6'/) - IRET = 6 - RETURN -C....................................................................... - END IF - -C LATITUDE (STORED AS REAL) - - M = 1 - IF(IPRINT.GT.1) PRINT 199, HDR(1),M - 199 FORMAT(5X,'HDR HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF(HDR(1).LT.XMSG) THEN - RDATX(1) = NINT(HDR(1) * 100.) - NNNNN = 1 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - 198 FORMAT(5X,'RDATA(',I5,') STORED AS: ',F10.2) - ELSE - IRET = 2 - PRINT 102 - 102 FORMAT(' *** W3UNPK77 ERROR: LAT MISSING FOR GOES SOUNDING'/) - RETURN - END IF - -C LONGITUDE (STORED AS REAL) - - M = 2 - IF(IPRINT.GT.1) PRINT 199, HDR(2),M - IF(HDR(2).LT.XMSG) THEN - RDATX(2) = NINT(MOD((36000.-(HDR(2)*100.)),36000.)) - NNNNN = 2 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - ELSE - IRET = 2 - PRINT 104 - 104 FORMAT(' *** W3UNPK77 ERROR: LON MISSING FOR GOES SOUNDING'/) - RETURN - END IF - -C NUMBER OF FIELDS OF VIEW - SAMPLE SIZE (STORED AS INTEGER) - - M = 3 - IF(IPRINT.GT.1) PRINT 199, HDR(3),M - IF(HDR(3).LT.XMSG) IDATA(3) = NINT(HDR(3)) - NNNNN = 3 - IF(IPRINT.GT.1) PRINT 197, NNNNN,IDATA(NNNNN) - 197 FORMAT(5X,'IDATA(',I5,') STORED AS: ',I10) - -C STATION ELEVATION (FROM HEIGHT OF FIRST -SURFACE- LEVEL) -C (STORED AS REAL) -- STORED IN SUBROUTINE UNPK7709 - - -C RETRIEVAL TYPE (GEOSTATIONARY SATELLITE DATA-PROCESSING -C TECHNIQUE USED) (STORED AS INTEGER) - - M = 4 - IF(IPRINT.GT.1) PRINT 199, HDR(4),M - IF(HDR(4).LT.XMSG) IDATA(8) = NINT(HDR(4)) - IRTYP = 3 - IF(IDATA(8).EQ.21) THEN - IRTYP = 1 - ELSE IF(IDATA(8).EQ.23) THEN - IRTYP = 2 - END IF - NNNNN = 8 - IF(IPRINT.GT.1) PRINT 197, NNNNN,IDATA(NNNNN) - -C PRODUCT QUALITY BIT FLAGS - QUALITY INFO. (STORED AS INTEGER) - - M = 5 - IF(IPRINT.GT.1) PRINT 199, HDR(5),M - IF(HDR(5).LT.XMSG) IDATA(10) = NINT(HDR(5)) - NNNNN = 10 - IF(IPRINT.GT.1) PRINT 197, NNNNN,IDATA(NNNNN) - -C STATION IDENTIFICATION (STORED AS CHARACTER) -C (FIRST 5-CHARACTERS OBTAINED FROM 5-DIGIT COUNT NUMBER, -C 6'TH CHARACTER OBTAINED FROM SAT. ID/RETRIEVAL TYPE TAG) - - WRITE(STNID(1:5),'(I5.5)') MIN(KOUNT,99999) - -C DECODE THE SATELLITE ID - - M = 6 - IDSAT = 2 - IF(IPRINT.GT.1) PRINT 199, HDR(6),M - IF(HDR(6).LT.XMSG) THEN - IDSAT = MOD(NINT(HDR(6)),4) - IF(NINT(HDR(6)).GT.249.AND.NINT(HDR(6)).LT.260) THEN - KNTSAT(NINT(HDR(6))) = KNTSAT(NINT(HDR(6))) + 1 - ELSE - KNTSAT(260) = KNTSAT(260) + 1 - END IF - END IF - IF(IPRINT.GT.1) PRINT 2197, IDSAT,IRTYP - 2197 FORMAT(5X,'IDSAT IS: ',I10,', IRTYP IS: ',I10) - STNID(6:6) = C6TAG(IRTYP,IDSAT) - COB(1:4) = STNID(1:4) - IDATA(11) = IOB - NNNNN = 11 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - 196 FORMAT(5X,'IDATA(',I5,') STORED IN CHARACTER AS: "',A4,'"') - COB(1:4) = STNID(5:6)//' ' - IDATA(12) = IOB - NNNNN = 12 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - -cvvvvvdak port -C LOAD THE YEAR/MONTH (STORED AS CHARACTER IN FORM YYMM) -caaaaadak port - - M = 7 - IF(IPRINT.GT.1) PRINT 199, HDR(7),M - IYEAR = IMSG - IF(HDR(7).LT.XMSG) IYEAR = NINT(HDR(7)) - M = 8 - IF(IPRINT.GT.1) PRINT 199, HDR(8),M - IF(HDR(8).LT.XMSG.AND.IYEAR.LT.IMSG) THEN -cvvvvvdak port - IYEAR = MOD(IYEAR,100) -caaaaadak port - IYEAR = NINT(HDR(8)) + (IYEAR * 100) -cvvvvvdak port -cdak WRITE(COB,'(I6.6,2X)') IYEAR - WRITE(COB,'(I4.4,4X)') IYEAR -caaaaadak port - IDATA(5) = IOB - NNNNN = 5 - IF(IPRINT.GT.1) PRINT 9196, NNNNN,COB(1:6) - 9196 FORMAT(5X,'IDATA(',I5,') STORED IN CHARACTER AS: "',A6,'"') - ELSE - GO TO 30 - END IF - -C LOAD THE DAY/HOUR (STORED AS CHARACTER IN FORM DDHH) -C AND THE OBSERVATION TIME (STORED AS REAL) - - M = 9 - IF(IPRINT.GT.1) PRINT 199, HDR(9),M - M = 10 - IF(IPRINT.GT.1) PRINT 199, HDR(10),M - IF(HDR(10).LT.XMSG.AND.HDR(9).LT.IMSG) THEN - M = 11 - IF(IPRINT.GT.1) PRINT 199, HDR(11),M - IF(HDR(11).GE.XMSG) GO TO 30 - M = 12 - IF(IPRINT.GT.1) PRINT 199, HDR(12),M - IF(HDR(12).GE.XMSG) GO TO 30 - RDATX(4) = NINT(((HDR(10) + ((HDR(11) * 60.) + HDR(12))/3600.) - $ * 100.) + 0.0000000001) - NNNNN = 4 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - IDAYHR = NINT(HDR(10)) + (NINT(HDR(9)) * 100) - WRITE(COB(1:4),'(I4.4)') IDAYHR - IDATA(6) = IOB - NNNNN = 6 - IF(IPRINT.GT.1) PRINT 196, NNNNN,COB(1:4) - ELSE - GO TO 30 - END IF - RDATA(1:1200) = RDATX(1:1200) - RETURN - 30 CONTINUE - IRET = 4 - RETURN - END -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: UNPK7709 FILLS CAT. 12,8 TO O-PUT ARRAY -GOES SNDG -C PRGMMR: D. A. KEYSER ORG: NP22 DATE: 1997-06-05 -C -C ABSTRACT: FOR REPORT (SUBSET) READ OUT OF BUFR MESSAGE (PASSED IN -C INTERNALLY VIA BUFRLIB STORAGE), CALLS BUFRLIB ROUTINE TO DECODE -C UPPER-AIR (SOUNDING) AND ADDITIONAL DATA FOR GOES SOUNDING. UPPER- -C AIR DATA ARE THEN FILLED INTO THE OUTPUT ARRAY AS CATEGORY 12 -C (SATELLITE SOUNDING) AND ADDITIONAL DATA ARE FILLED AS CATEGORY 8. -C THE OUPUT ARRAY HOLDS A SINGLE GOES SOUNDING IN THE QUASI-OFFICE -C NOTE 29 UNPACKED FORMAT. -C -C PROGRAM HISTORY LOG: -C 1997-06-05 D. A. KEYSER NP22 - ORIGINAL AUTHOR -C -C USAGE: CALL UNPK7709(LUNIT,RDATA,IRET) -C INPUT ARGUMENT LIST: -C LUNIT - FORTRAN UNIT NUMBER FOR INPUT DATA FILE -C RDATA - SINGLE GOES SNDG REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH ONLY HEADER INFORMATION FILLED -C - IN (CATEGORY 12 AND 8 DATA MISSING) -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C RDATA - SINGLE GOES SNDG REPORT IN A QUASI-OFFICE NOTE 29 -C - UNPACKED FORMAT WITH CATEGORY 12 AND 8 INFORMATION -C - FILLED IN (ALL DATA FOR REPORT NOW FILLED) -C IRET - RETURN CODE AS DESCRIBED IN W3UNPK77 DOCBLOCK -C -C OUTPUT FILES: -C UNIT 06 - PRINTOUT -C -C REMARKS: CALLED BY SUBROUTINE W3UNPK77. -C -C ATTRIBUTES: -C LANGUAGE: FORTRAN 90 -C MACHINE: IBM-SP, CRAY, SGI -C -C$$$ - SUBROUTINE UNPK7709(LUNIT,RDATA,IRET) - CHARACTER*1 CQMFLG - CHARACTER*8 COB - CHARACTER*37 CAT8A,CAT8B - CHARACTER*48 UAIR1,RAD1 - INTEGER IDATA(1200),ICDFG(12) - REAL(8) UAIR_8(4,255),CAT8_8(12),RTCSF_8,RAD_8(2,255) - REAL UAIR(4,255),CAT8(12),RDATA(*),RDATX(1200),SC8(12),RAD(2,255) - COMMON /PK77BB/kdate(8),ldate(8),IPRINT - COMMON /PK77FF/IFOV(3),KNTSAT(250:260) - - SAVE - - EQUIVALENCE (RDATX,IDATA),(COB,IOB) - DATA XMSG/99999./,YMSG/99999.8/ - DATA UAIR1/'PRLC HGHT TMDB TMDP '/ - DATA RAD1 /'CHNM TMBR '/ - DATA CAT8A/'GLFTI PH2O PH2O19 PH2O97 PH2O73 TMSK '/ - DATA CAT8B/'GCDTT CDTP CLAM SIDU SOEL ELEV '/ - DATA ICDFG/ 50 , 51 , 52 , 53 , 54 , 55 , 56 ,57 ,58,59, 60 , 61 / - DATA SC8/100.,100.,100.,100.,100.,100.,100.,10.,1.,1.,100.,100./ - RDATX(1:1200) = RDATA(1:1200) - -C ALL NON-RADIANCE DATA WILL BE Q.C.'D ACCORDING TO NUMBER OF FIELDS-OF- -C VIEW FOR RETRIEVAL: 0-2 --> BAD, 3-9 --> SUSPECT, 10-25 OR MISSING -C --> NEUTRAL - - CQMFLG = ' ' - IF(IDATA(3).LT.3) THEN - CQMFLG = 'F' - IFOV(1) = IFOV(1) + 1 - ELSE IF(IDATA(3).LT.10.OR.IDATA(10).EQ.1) THEN - CQMFLG = 'Q' - IF(IDATA(3).LT.10) IFOV(2) = IFOV(2) + 1 - END IF - IF(IDATA(3).GT.9) IFOV(3) = IFOV(3) + 1 - -C*********************************************************************** -C FILL CATEGORY 12 PART OF OUTPUT -C*********************************************************************** - - ILVL = 0 - ILC = 0 - UAIR_8 = 10.0E10 - CALL UFBINT(LUNIT,UAIR_8,4,255,NLEV,UAIR1);UAIR=UAIR_8 - IF(NLEV.EQ.0) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS ZERO -- - PRINT 217 - 217 FORMAT(/' ##W3UNPK77: NO UPPER-AIR (SOUNDING) DATA PROCESSED ', - $ 'FOR THIS REPORT -- NLEV = 0'/) - GO TO 98 - ELSE IF(NLEV.GT.50) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS GREATER THAN LIMIT OF 50 -- - PRINT 218 - 218 FORMAT(/' ##W3UNPK77: NO UPPER-AIR (SOUNDING) DATA PROCESSED ', - $ 'FOR THIS REPORT -- NLEV > 50'/) - GO TO 98 -C....................................................................... - END IF - IF(IPRINT.GT.1) PRINT 1068, NLEV - 1068 FORMAT(' THIS REPORT CONTAINS',I4,' INPUT LEVELS OF SOUNDING ', - $ 'DATA') - DO I = 1,NLEV - IF(IPRINT.GT.1) PRINT 1079, I,ILC,ILVL - 1079 FORMAT(' ATTEMPTING NEW CAT. 12 INPUT LEVEL NUMBER',I4,' WITH ', - $ 'ILC =',I5,'; NO. LEVELS PROCESSED TO NOW =',I5) - -C LEVEL PRESSURE (STORED AS REAL) - - M = 1 - IF(IPRINT.GT.1) PRINT 199, UAIR(1,I),M - 199 FORMAT(5X,'UAIR HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF(I.EQ.1) THEN - PSFC = UAIR(1,I) * 0.1 - ELSE IF(UAIR(1,I)*0.1.GE.YMSG) THEN -C WE DO NOT HAVE A VALID CATEGORY 12 LEVEL -- THERE IS NO VALID PRESSURE -C -- GO ON TO NEXT INPUT LEVEL (IF SFC LEVEL MSG, CONTINUE PROCESSING) - IF(IPRINT.GT.1) PRINT *, 'PRESSURE MISSING ON INPUT', - $ ' LEVEL ',I,', SKIP THE PROCESSING OF THIS LEVEL' - GO TO 10 - ELSE IF(UAIR(1,I)*0.1.GE.PSFC) THEN -C WE DO NOT HAVE A VALID CATEGORY 12 LEVEL -- THE INPUT LEVEL PRESSURE -C IS BELOW THE SURFACE PRESSURE -- GO ON TO THE NEXT INPUT LEVEL - IF(IPRINT.GT.1) PRINT *,'PRESSURE ON INPUT LEVEL ',I, - $ ' IS BELOW GROUND, SKIP THE PROCESSING OF THIS LEVEL' - GO TO 10 - END IF - -C WE HAVE A VALID CATEGORY 12 LEVEL -- THERE IS A VALID PRESSURE - - IF(UAIR(1,I)*0.1.LT.XMSG) RDATX(43+ILC) = NINT(UAIR(1,I)*0.1) - ILVL = ILVL + 1 - IF(IPRINT.GT.1) PRINT 198, 43+ILC,RDATX(43+ILC) - 198 FORMAT(5X,'RDATA(',I5,') STORED AS: ',F10.2) - -C GEOPOTENTIAL HEIGHT (STORED AS REAL) - - M = 2 - IF(IPRINT.GT.1) PRINT 199, UAIR(2,I),M - IF(UAIR(2,I).LT.XMSG) RDATX(43+ILC+1) = NINT(UAIR(2,I)) - IF(IPRINT.GT.1) PRINT 198, 43+ILC+1,RDATX(43+ILC+1) - IF(I.EQ.1) THEN - IF(IPRINT.GT.1) PRINT *, 'THIS IS SURFACE LEVEL, SO ', - $ 'STORE HEIGHT ALSO AS ELEVATION IN HEADER' - IF(UAIR(2,1).LT.XMSG) RDATX(7) = NINT(UAIR(2,1)) - NNNNN = 7 - IF(IPRINT.GT.1) PRINT 198, NNNNN,RDATX(NNNNN) - END IF - -C TEMPERATURE (STORED AS REAL) - - M = 3 - IF(IPRINT.GT.1) PRINT 199, UAIR(3,I),M - ITMP = NINT(UAIR(3,I)*100.) - IF(UAIR(3,I).LT.XMSG) - $ RDATX(43+ILC+2) = NINT((ITMP - 27315) * 0.1) - IF(IPRINT.GT.1) PRINT 198, 43+ILC+2,RDATX(43+ILC+2) - -C DEWPOINT TEMPERATURE (STORED AS REAL) - - M = 4 - IF(IPRINT.GT.1) PRINT 199, UAIR(4,I),M - ITMP = NINT(UAIR(4,I)*100.) - IF(UAIR(4,I).LT.XMSG) - $ RDATX(43+ILC+3) = NINT((ITMP - 27315) * 0.1) - IF(IPRINT.GT.1) PRINT 198, 43+ILC+3,RDATX(43+ILC+3) - -C QUALITY MARKERS (STORED AS CHARACTER) - - COB = CQMFLG//CQMFLG//CQMFLG//' ' - IDATA(43+ILC+6) = IOB - IF(IPRINT.GT.1) PRINT 196, 43+ILC+6,COB(1:4) - 196 FORMAT(5X,'IDATA(',I5,') STORED IN CHARACTER AS: "',A4,'"') -C....................................................................... - ILC = ILC + 7 - IF(I+1.LE.NLEV.AND.IPRINT.GT.1) PRINT *,'HAVE COMPLETED ', - $ 'LEVEL ',ILVL,'; GOING INTO NEXT LEVEL WITH ILC=',ILC - - 10 CONTINUE - ENDDO - -C SET CATEGORY COUNTERS FOR CATEGORY 12 (SOUNDING) DATA - - IDATA(39) = ILVL - 98 CONTINUE - IF(IPRINT.GT.1) PRINT *, IDATA(39),' CAT. 12 LEVELS PROCESSED' - IF(IDATA(39).GT.0) IDATA(40) = 43 - -C*********************************************************************** -C FILL CATEGORY 8 PART OF OUTPUT -C WILL ATTEMPT TO FILL 12 "LEVELS" -C LVL 1- LIFTED INDEX (DEG. K X 100 - RELATIVE) -------- CODE FIG. 250. -C LVL 2- TOTAL COLUMN PRECIPITABLE WATER (MM X 100) ---- CODE FIG. 251. -C LVL 3- 1. TO .9 SIGMA LAYER PRECIP. WATER (MM X 100) - CODE FIG. 252. -C LVL 4- .9 TO .7 SIGMA LAYER PRECIP. WATER (MM X 100) - CODE FIG. 253. -C LVL 5- .7 TO .3 SIGMA LAYER PRECIP. WATER (MM X 100) - CODE FIG. 254. -C LVL 6- SKIN TEMPERATURE (DEG. K X 100) --------------- CODE FIG. 255. -C LVL 7- CLOUD TOP TEMPERATURE (DEG. K X 100) ---------- CODE FIG. 256. -C LVL 8- CLOUD TOP PRESSURE (MB X 10) ------------------ CODE FIG. 257. -C LVL 9- CLOUD AMOUNT (C. FIG. BUFR TABLE 0-20-011) ---- CODE FIG. 258. -C LVL 10- INSTR. DATA USED IN PROC. -C (C. FIG. BUFR TABLE 0-02-021) --- CODE FIG. 259. -C LVL 11- SOLAR ZENITH ANGLE (SOLAR ELEV) (DEG. X 100) -- CODE FIG. 260. -C LVL 12- SATELLITE ZENITH ANGLE (ELEV) (DEG. X 100) --- CODE FIG. 261. -C -C IF DATA ONE ANY LEVEL ARE MISSING, THAT LEVEL IS NOT PROCESSED -C*********************************************************************** - - ILVL = 0 - ILC = 0 - CAT8_8 = 10.0E10 - CALL UFBINT(LUNIT,CAT8_8,12,1,NLEV8,CAT8A//CAT8B);CAT8=CAT8_8 - IF(NLEV8.NE.1) THEN - IF(NLEV8.EQ.0) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS ZERO -- - PRINT 318 - 318 FORMAT(/' ##W3UNPK77: NO ADDITIONAL (CAT. 8) DATA PROCESSED FOR ', - $ 'THIS REPORT -- NLEV8 = 0'/) - GO TO 99 -C....................................................................... - ELSE -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS NOT WHAT IS EXPECTED -- -C SET IRET = 7 AND RETURN - PRINT 219, NLEV8 - 219 FORMAT(/' ##W3UNPK77: THE NUMBER OF DECODED "LEVELS" (=',I5,') ', - $ 'IS NOT WHAT IS EXPECTED (1) - IRET = 7'/) - IRET = 7 - RETURN -C....................................................................... - END IF - END IF - -C THE TEMPERATURE CHANNEL SELECTION FLAG WILL BE USED LATER TO -C DETERMINE Q. MARK FOR SKIN TEMPERATURE (IF 0 - OK, OTHERWISE - BAD) - - RTCSF_8 = 10.0E10 - CALL UFBINT(LUNIT,RTCSF_8,1,1,NLEV0,'TCSF');RTCSF=RTCSF_8 - ITCSF = 1 - M = 1 - IF(IPRINT.GT.1) PRINT 299, RTCSF,M - 299 FORMAT(5X,'RTCSF HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF(RTCSF.LT.XMSG) ITCSF = NINT(RTCSF) - IF(IPRINT.GT.1) PRINT 1798, ITCSF - 1798 FORMAT(5X,'ITCSF IS: ',I10) - -C LOOP THROUGH THE 12 POSSIBLE ADDITIONAL DATA - - DO M = 1,12 - IF(IPRINT.GT.1) PRINT 6079, M,ILC,ILVL - 6079 FORMAT(' ATTEMPTING MISCEL. INPUT',I5,' WITH ILC =',I5,'; NO. ', - $ 'OUTPUT CAT. 8 LVLS PROCESSED TO NOW =',I5) - IF(IPRINT.GT.1) PRINT 399, CAT8(M),M - 399 FORMAT(5X,'CAT8 HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF(CAT8(M).LT.XMSG) THEN - -C WE HAVE A VALID CATEGORY 8 "LEVEL" - - ILVL = ILVL + 1 - -C STORE THE DATUM IN WORD 1 OF THE CAT. 8 LEVEL - - RDATX(393+ILC) = NINT(CAT8(M) * SC8(M)) - IF(IPRINT.GT.1) PRINT 198, 393+ILC,RDATX(393+ILC) - -C STORE THE CAT. 8 CODE FIGURE IN WORD 2 OF THE CAT. 8 LEVEL - - RDATX(393+ILC+1) = REAL(200+ICDFG(M)) - IF(IPRINT.GT.1) PRINT 198, 393+ILC+1,RDATX(393+ILC+1) - -C STORE THE QUALITY MARKER IN BYTE 1 OF WORD 3 OF THE CAT. 8 LEVEL - - COB = CQMFLG//' ' - -C IF THIS DATUM IS SKIN TEMPERATURE AND THE TEMPERATURE CHANNEL -C SELECTION FLAG IS BAD (.NE. 0), SET QUALITY MARKER TO "F" - - IF(M.EQ.6.AND.ITCSF.NE.0) COB(1:1) = 'F' - IDATA(393+ILC+2) = IOB - IF(IPRINT.GT.1) PRINT 196, 393+ILC+2,COB(1:4) - ILC = ILC + 3 - IF(M.LT.12.AND.IPRINT.GT.1) PRINT *,'HAVE COMPLETED OUTPUT', - $ ' LVL',ILVL,'; GOING INTO NEXT INPUT DATUM WITH ILC=',ILC - ELSE - IF(IPRINT.GT.1) PRINT *, 'DATUM MISSING ON INPUT ',M, - $ ', GO ON TO NEXT INPUT DATUM (NO. LVLS PROCESSED SO ', - $ 'FAR=',ILVL,'; ILC=',ILC,')' - END IF - ENDDO - -C SET CATEGORY COUNTERS FOR CATEGORY 8 (ADDITIONAL) DATA - - IDATA(27) = ILVL - 99 CONTINUE - IF(IPRINT.GT.1) PRINT *, IDATA(27),' CAT. 08 LEVELS PROCESSED' - IF(IDATA(27).GT.0) IDATA(28) = 393 - -C*********************************************************************** -C FILL CATEGORY 13 PART OF OUTPUT (RADIANCES) -C*********************************************************************** - - ILVL = 0 - ILC = 0 - RAD_8 = 10.0E10 - CALL UFBINT(LUNIT,RAD_8,2,255,NLEV13,RAD1);RAD=RAD_8 - IF(NLEV13.EQ.0) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS ZERO -- - PRINT 417 - 417 FORMAT(/' ##W3UNPK77: NO RADIANCE DATA PROCESSED FOR THIS ', - $ 'REPORT -- NLEV13 = 0'/) - GO TO 100 - ELSE IF(NLEV13.GT.60) THEN -C....................................................................... -C PROBLEM: THE NUMBER OF DECODED "LEVELS" IS GREATER THAN LIMIT OF 60 -- - PRINT 418 - 418 FORMAT(/' ##W3UNPK77: NO RADIANCE DATA PROCESSED FOR THIS ', - $ 'REPORT -- NLEV13 > 60'/) - GO TO 100 -C....................................................................... - END IF - IF(IPRINT.GT.1) PRINT 2068, NLEV13 - 2068 FORMAT(' THIS REPORT CONTAINS',I4,' INPUT LEVELS (CHANNELS) OF ', - $ 'RADIANCE DATA') - DO I = 1,NLEV13 - IF(IPRINT.GT.1) PRINT 2079, I,ILC,ILVL - 2079 FORMAT(' ATTEMPTING NEW CAT. 13 INPUT "LEVEL" NUMBER',I4,' WITH ', - $ 'ILC =',I5,'; NO. LEVELS (CHANNELS) PROCESSED TO NOW =',I5) - -C CHANNEL NUMBER (STORED AS INTEGER) - - M = 1 - IF(IPRINT.GT.1) PRINT 499, RAD(1,I),M - 499 FORMAT(5X,'RAD HERE IS: ',F17.4,'; INDEX IS: ',I3) - IF(RAD(1,I).GE.YMSG) THEN -C WE DO NOT HAVE A VALID CATEGORY 13 LEVEL -- THERE IS NO VALID CHANNEL -C NUMBER -- GO ON TO NEXT INPUT LEVEL - IF(IPRINT.GT.1) PRINT *, 'CHANNEL NUMBER MISSING ON INPUT', - $ ' LEVEL ',I,', SKIP THE PROCESSING OF THIS LEVEL' - GO TO 210 - END IF - -C WE HAVE A VALID CATEGORY 13 LEVEL -- THERE IS A VALID CHANNEL NUMBER - - IDATA(429+ILC) = NINT(RAD(1,I)) - ILVL = ILVL + 1 - IF(IPRINT.GT.1) PRINT 197, 429+ILC,IDATA(429+ILC) - 197 FORMAT(5X,'IDATA(',I5,') STORED AS: ',I10) - -C BRIGHTNESS TEMPERATURE (STORED AS REAL) - - M = 2 - IF(IPRINT.GT.1) PRINT 499, RAD(2,I),M - IF(RAD(2,I).LT.XMSG) RDATX(429+ILC+1) = NINT(RAD(2,I) * 100.) - IF(IPRINT.GT.1) PRINT 198, 429+ILC+1,RDATX(429+ILC+1) - -C QUALITY MARKERS (STORED AS CHARACTER) - - COB = ' ' - IDATA(429+ILC+2) = IOB - IF(IPRINT.GT.1) PRINT 196, 429+ILC+2,COB(1:4) -C....................................................................... - ILC = ILC + 3 - IF(I+1.LE.NLEV13.AND.IPRINT.GT.1) PRINT *,'HAVE COMPLETED ', - $ 'LEVEL ',ILVL,'; GOING INTO NEXT LEVEL WITH ILC=',ILC - - 210 CONTINUE - ENDDO - -C SET CATEGORY COUNTERS FOR CATEGORY 13 (RADIANCE) DATA - - IDATA(41) = ILVL - 100 CONTINUE - IF(IPRINT.GT.1) PRINT *, IDATA(41),' CAT. 13 LEVELS PROCESSED' - IF(IDATA(41).GT.0) IDATA(42) = 429 - - IF(IDATA(27)+IDATA(39)+IDATA(41).EQ.0) IRET = 5 - - IF(IPRINT.GT.1) PRINT *,'IDATA(39)=',IDATA(39),'; IDATA(40)=', - $ IDATA(40),'; IDATA(27)=',IDATA(27),'; IDATA(28)=',IDATA(28), - $ '; IDATA(41)=',IDATA(41),'; IDATA(42)=',IDATA(42) - - RDATA(1:1200) = RDATX(1:1200) - RETURN - END diff --git a/external/w3nco/v2.0.6/src/w3utcdat.f b/external/w3nco/v2.0.6/src/w3utcdat.f deleted file mode 100644 index 600f573b8..000000000 --- a/external/w3nco/v2.0.6/src/w3utcdat.f +++ /dev/null @@ -1,67 +0,0 @@ -!----------------------------------------------------------------------- - subroutine w3utcdat(idat) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3UTCDAT RETURN THE UTC DATE AND TIME -! AUTHOR: MARK IREDELL ORG: WP23 DATE: 98-01-05 -! -! ABSTRACT: THIS SUBPROGRAM RETURNS THE UTC (GREENWICH) DATE AND TIME -! IN THE NCEP ABSOLUTE DATE AND TIME DATA STRUCTURE. -! -! PROGRAM HISTORY LOG: -! 98-01-05 MARK IREDELL -! 1999-04-28 Gilbert - added a patch to check for the proper -! UTC offset. Needed until the IBM bug -! in date_and_time is fixed. The patch -! can then be removed. See comments in -! the section blocked with "&&&&&&&&&&&". -! 1999-08-12 Gilbert - Changed so that czone variable is saved -! and the system call is only done for -! first invocation of this routine. -! -! USAGE: CALL W3UTCDAT(IDAT) -! -! OUTPUT VARIABLES: -! IDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! -! SUBPROGRAMS CALLED: -! DATE_AND_TIME FORTRAN 90 SYSTEM DATE INTRINSIC -! IW3JDN COMPUTE JULIAN DAY NUMBER -! W3FS26 YEAR, MONTH, DAY FROM JULIAN DAY NUMBER -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - integer idat(8) - character cdate*8,ctime*10,czone*5 -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! get local date and time but use the character time zone - call date_and_time(cdate,ctime,czone,idat) - read(czone,'(i5)') idat(4) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! convert to hours and minutes to UTC time -! and possibly adjust the date as well - idat(6)=idat(6)-mod(idat(4),100) - idat(5)=idat(5)-idat(4)/100 - idat(4)=0 - if(idat(6).lt.00) then - idat(6)=idat(6)+60 - idat(5)=idat(5)-1 - elseif(idat(6).ge.60) then - idat(6)=idat(6)-60 - idat(5)=idat(5)+1 - endif - if(idat(5).lt.00) then - idat(5)=idat(5)+24 - jldayn=iw3jdn(idat(1),idat(2),idat(3))-1 - call w3fs26(jldayn,idat(1),idat(2),idat(3),idaywk,idayyr) - elseif(idat(5).ge.24) then - idat(5)=idat(5)-24 - jldayn=iw3jdn(idat(1),idat(2),idat(3))+1 - call w3fs26(jldayn,idat(1),idat(2),idat(3),idaywk,idayyr) - endif -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end diff --git a/external/w3nco/v2.0.6/src/w3valdat.f b/external/w3nco/v2.0.6/src/w3valdat.f deleted file mode 100644 index 6fa99f31c..000000000 --- a/external/w3nco/v2.0.6/src/w3valdat.f +++ /dev/null @@ -1,50 +0,0 @@ -!----------------------------------------------------------------------- - logical function w3valdat(idat) -!$$$ SUBPROGRAM DOCUMENTATION BLOCK -! -! SUBPROGRAM: W3VALDAT DETERMINE THE VALIDITY OF A DATE AND TIME -! AUTHOR: MARK IREDELL ORG: WP23 DATE: 98-01-05 -! -! ABSTRACT: THIS LOGICAL FUNCTION RETURNS TRUE IF THE INPUT IS A VALID -! NCEP ABSOLUTE DATE AND TIME. -! -! PROGRAM HISTORY LOG: -! 98-01-05 MARK IREDELL -! -! USAGE: ...=W3VALDAT(IDAT) -! -! INPUT VARIABLES: -! IDAT INTEGER (8) NCEP ABSOLUTE DATE AND TIME -! (YEAR, MONTH, DAY, TIME ZONE, -! HOUR, MINUTE, SECOND, MILLISECOND) -! -! OUTPUT VARIABLES: -! W3VALDAT LOGICAL TRUE IF IDAT IS A VALID NCEP DATE AND TIME -! -! SUBPROGRAMS CALLED: -! IW3JDN COMPUTE JULIAN DAY NUMBER -! W3FS26 YEAR, MONTH, DAY FROM JULIAN DAY NUMBER -! W3REDDAT REDUCE A TIME INTERVAL TO A CANONICAL FORM -! -! ATTRIBUTES: -! LANGUAGE: FORTRAN 90 -! -!$$$ - integer idat(8) - real rinc1(5),rinc2(5) - integer jdat(8) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -! essentially move the date and time by a zero time interval -! and see if the same date and time is returned - rinc1(1)=0 - rinc1(2:5)=idat(5:8) - call w3reddat(-1,rinc1,rinc2) - jldayn=iw3jdn(idat(1),idat(2),idat(3))+nint(rinc2(1)) - call w3fs26(jldayn,jdat(1),jdat(2),jdat(3),jdow,jdoy) -! the time zone is valid if it is in signed hhmm format -! with hh between -23 and 23 and mm equal to 00 or 30 - jdat(4)=mod(idat(4)/100,24)*100+mod(mod(idat(4),100),60)/30*30 - jdat(5:8)=nint(rinc2(2:5)) - w3valdat=all(idat.eq.jdat) -! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - end diff --git a/external/w3nco/v2.0.6/src/w3ymdh4.f b/external/w3nco/v2.0.6/src/w3ymdh4.f deleted file mode 100644 index 44a0f788c..000000000 --- a/external/w3nco/v2.0.6/src/w3ymdh4.f +++ /dev/null @@ -1,119 +0,0 @@ - SUBROUTINE W3YMDH4 (IDATE,IYEAR,MONTH,IDAY,IHOUR,NN) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C -C SUBPROGRAM: W3YMDH4 4-BYTE DATE WORD UNPACKER AND PACKER -C AUTHOR: Brill,K.F. ORG: NP/22 DATE: 98-07-29 -C -C ABSTRACT: OBTAINS THE COMPONENTS OF THE NMC DATE WORD (NCEP Y2K -C COMPLIANT FORM), OR GIVEN ITS COMPONENTS, FORMS AN NMC TYPE DATE -C WORD. THE PACKING IS DONE USING BASE 32. -C -C If the first byte of IDATE is less than 101, then the old -C Office Note 84 packing is assumed. A four-digit year is -C always returned. To pack the "old" way, pass in a 2-digit -C year. -C -C This program will work for the years ranging from A.D. 101 -C through 79359. -C -C On unpacking, years less than or equal to 100 are returned -C as follows: -C -C 0-50 2000--2050 -C 51-100 1951--2000 -C -C -C PROGRAM HISTORY LOG: -C 98-07-29 K.F.BRILL -C 1999-03-15 Gilbert - Removed Call to W3FS11 and put its -C processing inline. W3FS11 was deleted -C from the W3LIB. -C -C USAGE: CALL W3YMDH4 (IDATE, IYEAR, MONTH, IDAY, IHOUR, NN) -C -C INPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C IDATE ARG LIST LEFT 4 BYTES OF INTEGER 64 BIT WORD, OR CAN BE -C CHARACTER*1 IDATE(4) OR CHARACTER*4 IDATE. -C IYEAR ARG LIST INTEGER YEAR (4 DIGITS or 2 DIGITS for ON84) -C MONTH ARG LIST INTEGER MONTH -C IDAY ARG LIST INTEGER DAY -C IHOUR ARG LIST INTEGER HOUR -C NN ARG LIST INTEGER CODE: -C .EQ. 0 PACK IYEAR, MONTH, IDAY, IHOUR INTO IDATE -C .NE. 0 UNPACK IDATE INTO IYEAR, MONTH, IDAY, IHOUR -C -C OUTPUT VARIABLES: -C NAMES INTERFACE DESCRIPTION OF VARIABLES AND TYPES -C ------ --------- ----------------------------------------------- -C IDATE ARG LIST LEFT 4 BYTES OF INTEGER 64 BIT WORD, OR CAN BE -C CHARACTER*1 IDATE(4) OR CHARACTER*4 IDATE. -C IYEAR ARG LIST INTEGER YEAR (4 DIGITS) -C MONTH ARG LIST INTEGER MONTH -C IDAY ARG LIST INTEGER DAY -C IHOUR ARG LIST INTEGER HOUR -C -C SUBROGRAMS CALLED: -C NAMES LIBRARY -C ------------------------------------------------------- -------- -C CHAR F90 -C MOVA2I W3 -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT90 FORTRAN -C MACHINE: CRAY Y-MP8/832 -C -C$$$ -C - CHARACTER IDATE(4) -C - IF (NN.NE.0) THEN -C - ITEMP = MOVA2I(IDATE(1)) - IF ( ITEMP .lt. 101 ) THEN - IYEAR = MOVA2I(IDATE(1)) - MONTH = MOVA2I(IDATE(2)) - IDAY = MOVA2I(IDATE(3)) - IHOUR = MOVA2I(IDATE(4)) - IF(IYEAR.LE.100) IYEAR=2050-MOD(2050-IYEAR,100) - RETURN - END IF - ITEMP = ITEMP - 101 - ITEMP = ITEMP * 256 + MOVA2I(IDATE(2)) - ITEMP = ITEMP * 256 + MOVA2I(IDATE(3)) - ITEMP = ITEMP * 256 + MOVA2I(IDATE(4)) - IHOUR = MOD ( ITEMP, 32 ) - ITEMP = ITEMP / 32 - IDAY = MOD ( ITEMP, 32 ) - ITEMP = ITEMP / 32 - MONTH = MOD ( ITEMP, 32 ) - IYEAR = ITEMP / 32 -C - ELSE -C - ITEMP = IYEAR - IF ( ITEMP .lt. 101 ) THEN - IDATE(1) = CHAR(IYEAR) - IDATE(2) = CHAR(MONTH) - IDATE(3) = CHAR(IDAY) - IDATE(4) = CHAR(IHOUR) - RETURN - END IF - ITEMP = ITEMP * 32 + MONTH - ITEMP = ITEMP * 32 + IDAY - ITEMP = ITEMP * 32 + IHOUR -C* - IDATE(4)=CHAR(MOD(ITEMP,256)) - ITEMP = ITEMP / 256 - IDATE(3)=CHAR(MOD(ITEMP,256)) - ITEMP = ITEMP / 256 - IDATE(2)=CHAR(MOD(ITEMP,256)) - ITEMP = ITEMP / 256 - ITEMP = ITEMP + 101 - IDATE(1)=CHAR(ITEMP) -C - ENDIF -C - RETURN - END diff --git a/external/w3nco/v2.0.6/src/xmovex.f b/external/w3nco/v2.0.6/src/xmovex.f deleted file mode 100644 index 58c0aa089..000000000 --- a/external/w3nco/v2.0.6/src/xmovex.f +++ /dev/null @@ -1,20 +0,0 @@ - SUBROUTINE XMOVEX(OUT,IN,IBYTES) -C -C THIS SUBROUTINE MAY NOT BE NEEDED, ITS WAS IN -C ASSEMBLER LANGUAGE TO MOVE DATA, IT RAN ABOUT THREE -C TIMES FASTER THAN A FORTAN DO LOOP, IT WAS USED TO -C MAKE SURE THE DATA TO BE UNPACKED WAS ON A WORD BOUNDARY, -C THIS MAY NOT BE NEEDED ON SOME BRANDS OF COMPUTERS. -C - CHARACTER*1 OUT(*) - CHARACTER*1 IN(*) -C - INTEGER IBYTES -C - DO 100 I = 1,IBYTES - OUT(I) = IN(I) - 100 CONTINUE -C - RETURN - END - diff --git a/external/w3nco/v2.0.6/src/xstore.f b/external/w3nco/v2.0.6/src/xstore.f deleted file mode 100644 index a23b1f803..000000000 --- a/external/w3nco/v2.0.6/src/xstore.f +++ /dev/null @@ -1,44 +0,0 @@ - SUBROUTINE XSTORE(COUT,CON,MWORDS) -C$$$ SUBPROGRAM DOCUMENTATION BLOCK -C . . . . -C SUBPROGRAM: XSTORE STORES A CONSTANT VALUE INTO AN ARRAY -C PRGMMR: KEYSER ORG: W/NMC22 DATE: 07-02-92 -C -C ABSTRACT: STORES AN 8-BYTE (FULLWORD) VALUE THROUGH CONSECUTIVE -C STORAGE LOCATIONS. (MOVING IS ACCOMPLISHED WITH A DO LOOP.) -C -C PROGRAM HISTORY LOG: -C 92-07-02 D. A. KEYSER (W/NMC22) -C 95-10-31 IREDELL REMOVED SAVES AND PRINTS -C -C USAGE: CALL XSTORE(COUT,CON,MWORDS) -C INPUT ARGUMENT LIST: -C CON - CONSTANT TO BE STORED INTO "MWORDS" CONSECUTIVE -C FULLWORDS BEGINNING WITH "COUT" ARRAY -C MWORDS - NUMBER OF FULLWORDS IN "COUT" ARRAY TO STORE "CON"; -C MUST BE .GT. ZERO (NOT CHECKED FOR THIS) -C -C OUTPUT ARGUMENT LIST: (INCLUDING WORK ARRAYS) -C COUT - STARTING ADDRESS FOR ARRAY OF "MWORDS" FULLWORDS -C SET TO THE CONTENTS OF THE VALUE "CON" -C -C REMARKS: THE VERSION OF THIS SUBROUTINE ON THE HDS COMMON LIBRARY -C IS NAS-SPECIFIC SUBR. WRITTEN IN ASSEMBLY LANG. TO ALLOW FAST -C COMPUTATION TIME. SUBR. PLACED IN CRAY W3LIB TO ALLOW CODES TO -C COMPILE ON BOTH THE HDS AND CRAY MACHINES. -C SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT. -C -C ATTRIBUTES: -C LANGUAGE: CRAY CFT77 FORTRAN -C MACHINE: CRAY Y-MP8/864 -C -C$$$ -C - DIMENSION COUT(*) -C - DO 1000 I = 1,MWORDS - COUT(I) = CON -1000 CONTINUE -C - RETURN - END From c292da11df8352b1326b7826a11b6b16ba117c02 Mon Sep 17 00:00:00 2001 From: "Grant.Firl" Date: Tue, 4 Jun 2019 18:52:29 -0600 Subject: [PATCH 4/9] correct syntax in .csh setup scripts --- scm/etc/Cheyenne_setup_pgi.csh | 4 ++-- scm/etc/Theia_setup_gnu.csh | 4 ++-- scm/etc/Theia_setup_intel.csh | 4 ++-- scm/etc/Theia_setup_pgi.csh | 4 ++-- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/scm/etc/Cheyenne_setup_pgi.csh b/scm/etc/Cheyenne_setup_pgi.csh index 9658aa2fb..767666b26 100755 --- a/scm/etc/Cheyenne_setup_pgi.csh +++ b/scm/etc/Cheyenne_setup_pgi.csh @@ -16,8 +16,8 @@ setenv CXX pgc++ setenv FC pgf90 echo "Setting NCEPLIBS_DIR environment variable" -set NCEPLIBS_DIR /glade/p/ral/jntp/GMTB/tools/NCEPlibs/20190307/pgi-17.9/mpt-2.19 -setenv NCEPLIBS_DIR ${NCEPLIBS_DIR} +set NCEPLIBS_DIR = "/glade/p/ral/jntp/GMTB/tools/NCEPlibs/20190307/pgi-17.9/mpt-2.19" +setenv NCEPLIBS_DIR $NCEPLIBS_DIR #install f90nml for the local user diff --git a/scm/etc/Theia_setup_gnu.csh b/scm/etc/Theia_setup_gnu.csh index 74179b1e0..d0915daee 100755 --- a/scm/etc/Theia_setup_gnu.csh +++ b/scm/etc/Theia_setup_gnu.csh @@ -27,8 +27,8 @@ setenv CXX g++ setenv FC gfortran echo "Setting NCEPLIBS_DIR environment variable" -set NCEPLIBS_DIR /scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-gnu-20181105 -setenv NCEPLIBS_DIR ${NCEPLIBS_DIR} +set NCEPLIBS_DIR = "/scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-gnu-20181105" +setenv NCEPLIBS_DIR $NCEPLIBS_DIR #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" diff --git a/scm/etc/Theia_setup_intel.csh b/scm/etc/Theia_setup_intel.csh index e9ab5ba46..5649c1bc9 100755 --- a/scm/etc/Theia_setup_intel.csh +++ b/scm/etc/Theia_setup_intel.csh @@ -14,8 +14,8 @@ setenv CXX icpc setenv FC ifort echo "Setting NCEPLIBS_DIR environment variable" -set NCEPLIBS_DIR /scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-intel-18.1.163-20181105 -setenv NCEPLIBS_DIR ${NCEPLIBS_DIR} +set NCEPLIBS_DIR = "/scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-intel-18.1.163-20181105" +setenv NCEPLIBS_DIR $NCEPLIBS_DIR #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" diff --git a/scm/etc/Theia_setup_pgi.csh b/scm/etc/Theia_setup_pgi.csh index ead9a1a3c..505eb8cba 100755 --- a/scm/etc/Theia_setup_pgi.csh +++ b/scm/etc/Theia_setup_pgi.csh @@ -14,8 +14,8 @@ setenv CXX pgc++ setenv FC pgf90 echo "Setting NCEPLIBS_DIR environment variable" -set NCEPLIBS_DIR /scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-pgi-20181105 -setenv NCEPLIBS_DIR ${NCEPLIBS_DIR} +set NCEPLIBS_DIR = "/scratch4/home/Dom.Heinzeller/NEMSfv3gfs_vlab_portability/NCEPlibs-pgi-20181105" +setenv NCEPLIBS_DIR $NCEPLIBS_DIR #prepend the anaconda installation to the path so that the anaconda version of python (with its many installed modules) is used; check if the path already contains the right path first echo "Checking if the path to the anaconda python distribution is in PATH" From 01374c4d068423050981d76c0af15009a1cbdb63 Mon Sep 17 00:00:00 2001 From: "Grant.Firl" Date: Tue, 4 Jun 2019 19:00:27 -0600 Subject: [PATCH 5/9] added missing $ in CMakeLists.txt --- scm/src/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/scm/src/CMakeLists.txt b/scm/src/CMakeLists.txt index 6a99672a6..ca4107b1c 100644 --- a/scm/src/CMakeLists.txt +++ b/scm/src/CMakeLists.txt @@ -17,7 +17,7 @@ ENDIF(DEFINED ENV{NETCDF}) set(NCEPLIBS_DIR /usr/local/NCEPlibs-20180401) IF(DEFINED ENV{NCEPLIBS_DIR}) MESSAGE("The NCEPLIBS_DIR env. variable is $ENV{NCEPLIBS_DIR}") - set(NCEPLIBS_DIR ENV{NCEPLIBS_DIR}) + set(NCEPLIBS_DIR $ENV{NCEPLIBS_DIR}) ELSE(DEFINED ENV{NCEPLIBS_DIR}) MESSAGE("The NCEPLIBS_DIR env. variable is not set. Setting to default value: ${NCEPLIBS_DIR}") ENDIF(DEFINED ENV{NCEPLIBS_DIR}) From cfdfd866928c136be140f83e34a88d1c368cd774 Mon Sep 17 00:00:00 2001 From: "Grant.Firl" Date: Tue, 4 Jun 2019 19:43:01 -0600 Subject: [PATCH 6/9] updating docs associated with removing internal NCEPlibs --- README.md | 18 ++++++++++++++++++ scm/doc/TechGuide/chap_quick.tex | 16 +++++++++++++++- scm/doc/TechGuide/chap_repo.tex | 4 ---- scm/doc/TechGuide/main.pdf | Bin 511279 -> 512658 bytes 4 files changed, 33 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index caf9b72c3..b0b5b2cdd 100644 --- a/README.md +++ b/README.md @@ -7,6 +7,24 @@ CCPP infrastructure code and physics code, both of which are included as git submodules within the SCM code. This package can be considered a simple example for an atmospheric model to interact with physics through the CCPP. +## Prerequisite +There are several utility libraries as part of the NCEPlibs package that must be installed prior to building the SCM. +* bacio - Binary I/O Library +* sp - Spectral Transformation Library +* w3nco - GRIB decoder and encoder library + +These libraries are prebuilt on most NOAA machines using the Intel compiler. For those needing to build the libraries themselves, GMTB recommends using the source code from GitHub at https://github.com/NCAR/NCEPlibs.git, which includes build files for various compilers and machines using OpenMP flags and which are threadsafe. Instructions for installing NCEPlibs are included on the GitHub repository webpage, but for the sake of example, execute the following for obtaining and building from source in /usr/local/NCEPlibs on a Mac: +1. `cd /usr/local/src` +2. `git clone https://github.com/NCAR/NCEPlibs.git` +3. `cd NCEPlibs` +4. `./make_ncep_libs.sh -s macosx -c gnu -d /usr/local/NCEPlibs -o 1` + +Once NCEPlibs is built, the NCEPLIBS_DIR environment variable must be set to the location of the installation. For example, if NCEPlibs was installed in /usr/local/NCEPlibs, one would execute + +`export NCEPLIB_DIR=/usr/local/NCEPlibs` + +If using Theia or Cheyenne HPC systems, this environment variable is automatically set to an appropriate installation of NCEPlibs on those machines through use of one of the setup scripts described below. + ## Obtaining Code 1. Download a compressed file or clone the source using * `git clone https://[username]@github.com/NCAR/gmtb-scm.git` diff --git a/scm/doc/TechGuide/chap_quick.tex b/scm/doc/TechGuide/chap_quick.tex index 747d91398..aad19321c 100644 --- a/scm/doc/TechGuide/chap_quick.tex +++ b/scm/doc/TechGuide/chap_quick.tex @@ -66,12 +66,26 @@ \section{System Requirements, Libraries, and Tools} Because these tools and libraries are typically the purview of system administrators to install and maintain, they are considered part of the basic system requirements. -There are several utility libraries provided in the SCM bundle, as external packages. These are built during the compilation phase, and include +Further, there are several utility libraries as part of the NCEPlibs package that must be installed prior to building the SCM. \begin{itemize} \item bacio - Binary I/O Library \item sp - Spectral Transformation Library \item w3nco - GRIB decoder and encoder library \end{itemize} +These libraries are prebuilt on most NOAA machines using the Intel compiler. For those needing to build the libraries themselves, GMTB recommends using the source code from GitHub at \url{https://github.com/NCAR/NCEPlibs.git}, which includes build files for various compilers and machines using OpenMP flags and which are threadsafe. Instructions for installing NCEPlibs are included on the GitHub repository webpage, but for the sake of example, execute the following for obtaining and building from source in \execout{/usr/local/NCEPlibs} on a Mac: +\begin{lstlisting} + mkdir /usr/local/NCEPlibs + cd /usr/local/src + git clone https://github.com/NCAR/NCEPlibs.git + cd NCEPlibs + ./make_ncep_libs.sh -s macosx -c gnu -d /usr/local/NCEPlibs -o 1 +\end{lstlisting} +Once NCEPlibs is built, the \execout{NCEPLIBS\_DIR} environment variable must be set to the location of the installation. For example, if NCEPlibs was installed in \execout{/usr/local/NCEPlibs}, one would execute +\begin{lstlisting} +export NCEPLIB_DIR=/usr/local/NCEPlibs +\end{lstlisting} +If using Theia or Cheyenne HPC systems, this environment variable is automatically set to an appropriate installation of NCEPlibs on those machines through use of one of the setup scripts described in section \ref{section: compiling}. + \subsection{Compilers} The CCPP and SCM have been tested on a variety of diff --git a/scm/doc/TechGuide/chap_repo.tex b/scm/doc/TechGuide/chap_repo.tex index a1bf7b513..5b5c488d9 100644 --- a/scm/doc/TechGuide/chap_repo.tex +++ b/scm/doc/TechGuide/chap_repo.tex @@ -34,10 +34,6 @@ \section{What is included in the repository?} .3 config/\DTcomment{contains the CCPP prebuild config}. .3 suites/\DTcomment{contains suite definition files}. .3 physics\_namelists\DTcomment{contains physics namelist files associated with suites}. - .2 external/. - .3 bacio\DTcomment{NCEP library bacio (needed for GFS physics)}. - .3 sp\DTcomment{NCEP library sp (needed for GFS physics)}. - .3 w3nco\DTcomment{NCEP library w3 (needed for GFS physics and SCM infrastructure)}. .2 scm/. .3 bin/\DTcomment{build directory (initially empty; populated by cmake)}. .3 data/. diff --git a/scm/doc/TechGuide/main.pdf b/scm/doc/TechGuide/main.pdf index 8a816df638a253ffed8be205df82d1ba9b366815..d7ecaca3ccc8d547be80fde4d5b06d0b4b705fbc 100644 GIT binary patch delta 126702 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%0A_a{@o;$AoEia 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%0D`_brise<&!SQG-a*ehe`n zg1dNHdU4U%Ycae3!jEiXT=e*kFH8JHctE{P|4M*x2&C{a|n^;O;{ZdmXY zwo|>;eTZAfL5%M&-F2%yj}#k~^CcT?tJQ?@e03yvY@=ENI*YZd6k%{I7TdV33S!Ua z3hi%F&|6IApCQZHLQI_w_*U%U$!Q{4_z~Xg8+#h*SW1wIgp8~KMv}3@f15&HEJS`{ zt619?qlqxv6P9{KwRCw6a_F93KMk70ccPuurfTD<$?UPxv9||4C|Z_iBR6%B?Z_r{ zlHb8$S}6$!vh#)#d%d+iC7d*YOn|w4>A}(1yXL5LPxxyV?~Fb# zR^|X8xi9d7mZZNZ4?`5Ue=R+<|!*)d|zJF8K_Z5}Lnf2T-`oK(Kd^>Dir zA<101NEPETmIZ6ZhxmrTXZ]k9(gI*`?1d;DMs^6mVcbiFRne71`#mHLi#$NaqE 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 Date: Wed, 5 Jun 2019 14:48:07 -0600 Subject: [PATCH 7/9] updated machine setup files on Cheyenne for intel and gnu --- scm/doc/TechGuide/main.pdf | Bin 512658 -> 512764 bytes scm/etc/Cheyenne_setup_gnu.csh | 4 ++++ scm/etc/Cheyenne_setup_gnu.sh | 5 +++++ scm/etc/Cheyenne_setup_intel.csh | 4 ++++ scm/etc/Cheyenne_setup_intel.sh | 4 ++++ 5 files changed, 17 insertions(+) diff --git a/scm/doc/TechGuide/main.pdf b/scm/doc/TechGuide/main.pdf index d7ecaca3ccc8d547be80fde4d5b06d0b4b705fbc..e02ffc86b97907d7a1a375f40bc70c27df5528a7 100644 GIT binary patch delta 24704 zcmYhiWmF}xwl&Je-L-Ldw~aUM?(Xi5>joNkcWE3NcXxMpZJfp(8vD5C-22A+ks6hZ zS~E#iWv$GaB(a$It(dsB+Y_9fCn+JHHtEz85yTS&i|Tu*rW>&vPu9`;yBPYhk(WQG_XtN@MAKK~p6j z52=tWg$5bXFq$({ohj$G*Vcn#&ZS)UYR>kce&GLip;?l}bta6BnF_@C(L~zy0uN<) z3Tm9?++E_iq{|Vb$cJ}cC|{I;;-TFDyYkl93EU%hCFxT5^)8~T!vC12uv zpfNk_AnGK4%>`oNc`V`!Aw^(5 za2q{IfOQR{ld5&YTuWl!PZn`T;^G)$67=&vUOg}U{uDNI^--B+wj@|PV{S{p?c~GF z2&QT)�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 rBq&(th|F5C~1+#kqs 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 L@j^jM5&QoDkwWwy diff --git a/scm/etc/Cheyenne_setup_gnu.csh b/scm/etc/Cheyenne_setup_gnu.csh index a49044863..733e34d97 100755 --- a/scm/etc/Cheyenne_setup_gnu.csh +++ b/scm/etc/Cheyenne_setup_gnu.csh @@ -16,6 +16,10 @@ setenv CC gcc setenv CXX g++ setenv FC gfortran +echo "Setting NCEPLIBS_DIR environment variable" +set NCEPLIBS_DIR = "/glade/p/ral/jntp/GMTB/tools/NCEPlibs/20190307/gnu-8.1.0/mpt-2.19" +setenv NCEPLIBS_DIR $NCEPLIBS_DIR + #install f90nml for the local user #check to see if f90nml is installed locally diff --git a/scm/etc/Cheyenne_setup_gnu.sh b/scm/etc/Cheyenne_setup_gnu.sh index 7ab38409c..a04919221 100755 --- a/scm/etc/Cheyenne_setup_gnu.sh +++ b/scm/etc/Cheyenne_setup_gnu.sh @@ -17,6 +17,11 @@ export CC=gcc export CXX=g++ export FC=gfortran +echo "Setting NCEPLIBS_DIR environment variable" +NCEPLIBS_DIR=/glade/p/ral/jntp/GMTB/tools/NCEPlibs/20190307/gnu-8.1.0/mpt-2.19 +export NCEPLIBS_DIR=$NCEPLIBS_DIR + + #install f90nml for the local user #check to see if f90nml is installed locally diff --git a/scm/etc/Cheyenne_setup_intel.csh b/scm/etc/Cheyenne_setup_intel.csh index 3ff00f1be..7e5d678b3 100755 --- a/scm/etc/Cheyenne_setup_intel.csh +++ b/scm/etc/Cheyenne_setup_intel.csh @@ -16,6 +16,10 @@ setenv CC icc setenv CXX icpc setenv FC ifort +echo "Setting NCEPLIBS_DIR environment variable" +set NCEPLIBS_DIR = "/glade/p/ral/jntp/GMTB/tools/NCEPlibs/20190307/intel-19.0.2/mpt-2.19" +setenv NCEPLIBS_DIR $NCEPLIBS_DIR + #install f90nml for the local user #check to see if f90nml is installed locally diff --git a/scm/etc/Cheyenne_setup_intel.sh b/scm/etc/Cheyenne_setup_intel.sh index e7c834533..4960e64c6 100755 --- a/scm/etc/Cheyenne_setup_intel.sh +++ b/scm/etc/Cheyenne_setup_intel.sh @@ -16,6 +16,10 @@ export CC=icc export CXX=icpc export FC=ifort +echo "Setting NCEPLIBS_DIR environment variable" +NCEPLIBS_DIR=/glade/p/ral/jntp/GMTB/tools/NCEPlibs/20190307/intel-19.0.2/mpt-2.19 +export NCEPLIBS_DIR=$NCEPLIBS_DIR + #install f90nml for the local user #check to see if f90nml is installed locally From dc09478b5882b6f0bf2c5c633423e4e89305e548 Mon Sep 17 00:00:00 2001 From: "Grant.Firl" Date: Wed, 5 Jun 2019 15:55:42 -0600 Subject: [PATCH 8/9] remove NCEPLIBS_DIR fallback --- scm/src/CMakeLists.txt | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/scm/src/CMakeLists.txt b/scm/src/CMakeLists.txt index ca4107b1c..e69337477 100644 --- a/scm/src/CMakeLists.txt +++ b/scm/src/CMakeLists.txt @@ -14,12 +14,11 @@ ELSE(DEFINED ENV{NETCDF}) MESSAGE(FATAL_ERROR "The NETCDF environement variable must be set to point to your NetCDF installation before building. Stopping...") ENDIF(DEFINED ENV{NETCDF}) -set(NCEPLIBS_DIR /usr/local/NCEPlibs-20180401) IF(DEFINED ENV{NCEPLIBS_DIR}) MESSAGE("The NCEPLIBS_DIR env. variable is $ENV{NCEPLIBS_DIR}") set(NCEPLIBS_DIR $ENV{NCEPLIBS_DIR}) ELSE(DEFINED ENV{NCEPLIBS_DIR}) - MESSAGE("The NCEPLIBS_DIR env. variable is not set. Setting to default value: ${NCEPLIBS_DIR}") + MESSAGE(FATAL_ERROR "The NCEPLIBS_DIR environment variable must be set to point to your NCEPlibs installation before building. Stopping...") ENDIF(DEFINED ENV{NCEPLIBS_DIR}) set(BACIO_LIB4 ${NCEPLIBS_DIR}/lib/libbacio_4.a) From 0e3dde4833249538dab9e4f92c2d20fde2d9cd34 Mon Sep 17 00:00:00 2001 From: "Grant.Firl" Date: Wed, 5 Jun 2019 16:16:30 -0600 Subject: [PATCH 9/9] updated submodule pointers --- ccpp/framework | 2 +- ccpp/physics | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/ccpp/framework b/ccpp/framework index 0c04005ed..db5c28c35 160000 --- a/ccpp/framework +++ b/ccpp/framework @@ -1 +1 @@ -Subproject commit 0c04005ed3eed7be0e2f9d053ee080368383b6fa +Subproject commit db5c28c35e87500ec040011c756de1397aec1bff diff --git a/ccpp/physics b/ccpp/physics index fba8a177b..245d228a1 160000 --- a/ccpp/physics +++ b/ccpp/physics @@ -1 +1 @@ -Subproject commit fba8a177bf6f57e238507b0df943b7c0db7333fa +Subproject commit 245d228a1d26b24f91b7f8d4014a7a66c21b8441