Merge branch 'eccodes' of ssh://software.ecmwf.int:7999/GRIB/grib_api into eccodes

This commit is contained in:
Shahram Najm 2015-03-16 17:50:53 +00:00
commit b52d103cfe
9 changed files with 363 additions and 12 deletions

View File

@ -11,7 +11,7 @@
/*
* C Implementation: bufr_read_temp
*
* Description: how to read a temperature significant levels from TEMP BUFR messages.
* Description: how to read temperature significant levels from TEMP BUFR messages.
*
*/
@ -58,8 +58,8 @@ int main(int argc,char* argv[])
i.e. unpack the data values */
CODES_CHECK(codes_set_long(h,"unpack",1),0);
/* In what follows: we rely on the fact that for
temperature signifcant levels the value of key
/* In what follows we rely on the fact that for
temperature significant levels the value of key
verticalSoundingSignificance is 4 (see flag table 8001 for details).
We also make use of the fact that in our BUFR message
@ -71,8 +71,8 @@ int main(int argc,char* argv[])
Get the number of the temperature significant levels.
------------------------------------------------------*/
/* We find out the number of significant temperature levels by
counting how many presssure values we have on these levels. */
/* We find out the number of temperature significant levels by
counting how many pressure values we have on these levels. */
sprintf(key_name,"/verticalSoundingSignificance=4/pressure");
CODES_CHECK(codes_get_size(h,key_name,&sigt_len),0);
@ -106,7 +106,7 @@ int main(int argc,char* argv[])
CODES_CHECK(codes_get_size(h,key_name,&len),0);
if(len != sigt_len)
{
printf("incosistent number of geopotential values found!\n");
printf("inconsistent number of geopotential values found!\n");
return 1;
}
@ -122,7 +122,7 @@ int main(int argc,char* argv[])
/* Check the size*/
if(len != sigt_len)
{
printf("incosistent number of temperature values found!\n");
printf("inconsistent number of temperature values found!\n");
return 1;
}
@ -139,7 +139,7 @@ int main(int argc,char* argv[])
/* Check the size*/
if(len != sigt_len)
{
printf("incosistent number of dewpoint temperature values found!\n");
printf("inconsistent number of dewpoint temperature values found!\n");
return 1;
}

View File

@ -36,6 +36,7 @@ list( APPEND tests
bufr_keys_iterator
bufr_print_header
bufr_print_data
bufr_read_temp
bufr_set_keys
bufr_subset
get_product_kind

View File

@ -5,14 +5,14 @@ TESTS = copy_message.sh get.sh get_data.sh get_pl.sh get_pv.sh keys_iterator.sh
nearest.sh precision.sh multi_write.sh multi.sh print_data.sh set.sh set_bitmap.sh set_missing.sh \
set_pv.sh samples.sh count_messages.sh read_message.sh read_from_file.sh index.sh get_set_uuid.sh \
bufr_attributes.sh bufr_clone.sh bufr_expanded.sh bufr_get_keys.sh bufr_print_header.sh bufr_print_data.sh bufr_set_keys.sh \
bufr_keys_iterator.sh bufr_subset.sh get_product_kind.sh
bufr_keys_iterator.sh bufr_subset.sh get_product_kind.sh bufr_read_temp.sh
noinst_PROGRAMS = f_index f_copy_message f_get f_get_data f_get_pl f_get_pv f_keys_iterator \
f_multi_write f_multi f_nearest f_precision f_print_data f_set f_set_bitmap f_set_missing \
f_set_pv f_samples f_count_messages f_read_message f_read_from_file f_new_from_file \
f_copy_namespace f_get_set_uuid f_set_gvc f_clone f_bufr_clone f_bufr_expanded f_bufr_get_keys \
f_bufr_print_header f_bufr_print_data f_bufr_set_keys f_bufr_keys_iterator f_bufr_subset f_bufr_attributes \
f_get_product_kind
f_get_product_kind f_bufr_read_temp
f_index_SOURCES=index.f90
f_copy_message_SOURCES=copy_message.f90
@ -46,6 +46,7 @@ f_bufr_get_keys_SOURCES=bufr_get_keys.f90
f_bufr_keys_iterator_SOURCES=bufr_keys_iterator.f90
f_bufr_print_header_SOURCES=bufr_print_header.f90
f_bufr_print_data_SOURCES=bufr_print_data.f90
f_bufr_read_temp_SOURCES=bufr_read_temp.f90
f_bufr_set_keys_SOURCES=bufr_set_keys.f90
f_bufr_subset_SOURCES=bufr_subset.f90
f_get_product_kind_SOURCES=get_product_kind.f90

View File

@ -0,0 +1,151 @@
!
!Copyright 2005-2015 ECMWF.
!
! This software is licensed under the terms of the Apache Licence Version 2.0
!which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
!
! In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
! virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
!
!
! FOTRAN 90 Implementation: bufr_read_temp
!
! Description: how to read temperature significant levels from TEMP BUFR messages.
!
!
program bufr_print_data
use eccodes
implicit none
integer :: ifile
integer :: iret
integer :: ibufr
integer :: i, count=0
integer(kind=4) :: numSigT
integer(kind=4) :: num
real(kind=8), dimension(:), allocatable :: presVal,geoVal,tVal ,tdVal
character(len=128) :: keyName
call codes_open_file(ifile,'../../data/bufr/temp_101.bufr','r')
! the first bufr message is loaded from file
! ibufr is the bufr id to be used in subsequent calls
call codes_bufr_new_from_file(ifile,ibufr,iret)
do while (iret/=CODES_END_OF_FILE)
write(*,*) 'message: ',count
! we need to instruct ecCodes to expand all the descriptors
! i.e. unpack the data values
call codes_set(ibufr,"unpack",1);
! In what follows we rely on the fact that for
! temperature significant levels the value of key
! verticalSoundingSignificance is 4 (see flag table 8001 for details).
! We also make use of the fact that in our BUFR message
! verticalSoundingSignificance is always followed by geopotential,
! airTemperature, dewpointTemperature,
! windDirection, windSpeed and pressure.
! ---- Get the number of the temperature significant levels ----
! We find out the number of temperature significant levels by
! counting how many pressure values we have on these levels.
keyName="/verticalSoundingSignificance=4/pressure"
call codes_get_size(ibufr,keyName,numSigT);
write(*,*) "Number of temperature significant levels:", numSigT
! Allocate memory for the values to be read. Each
! parameter must have the same number of values.
allocate(presVal(numSigT), stat=iret);
allocate(geoVal(numSigT), stat=iret);
allocate(tVal(numSigT), stat=iret);
allocate(tdVal(numSigT), stat=iret);
! ---- Get pressure ---------------------------
keyName="/verticalSoundingSignificance=4/pressure"
! get the value
call codes_get(ibufr,keyName,presVal);
! ---- Get gepotential ------------------------
keyName="/verticalSoundingSignificance=4/geopotential"
!Check the size
call codes_get_size(ibufr,keyName,num)
if (num /= numSigT) then
write(*,*) "inconsistent number of geopotential values found!"
call exit(1)
end if
! get the values
call codes_get(ibufr,keyName,geoVal)
! ---- Get temperature --------------------------------
keyName="/verticalSoundingSignificance=4/airTemperature"
!Check the size
call codes_get_size(ibufr,keyName,num)
if (num /= numSigT) then
write(*,*) "inconsistent number of temperature values found!"
call exit(1)
end if
! get the values
call codes_get(ibufr,keyName,tVal)
! ---- Get dew point temperature -----------------------
keyName="/verticalSoundingSignificance=4/dewpointTemperature"
!Check the size
call codes_get_size(ibufr,keyName,num)
if (num /= numSigT) then
write(*,*) "inconsistent number of dew point temperature values found!"
call exit(1)
end if
! get the values
call codes_get(ibufr,keyName,tdVal)
! ---- Print the values --------------------------------
write(*,*) 'level pres geo t td'
write(*,*) "--------------------------------------"
do i=1,numSigT
write(*,*) i,presVal(i),geoVal(i),tVal(i),tdVal(i)
end do
! free arrays
deallocate(presVal)
deallocate(geoVal)
deallocate(tVal)
deallocate(tdVal)
! release the bufr message
call codes_release(ibufr)
! load the next bufr message
call codes_bufr_new_from_file(ifile,ibufr,iret)
count=count+1
end do
! close file
call codes_close_file(ifile)
end program bufr_print_data

35
examples/F90/bufr_read_temp.sh Executable file
View File

@ -0,0 +1,35 @@
#!/bin/sh
# Copyright 2005-2015 ECMWF.
#
# This software is licensed under the terms of the Apache Licence Version 2.0
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
#
# In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
# virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
#
. ./include.sh
#Define a common label for all the tmp files
label="bufr_read_temp_f"
#Define tmp file
fTmp=${label}.tmp.txt
rm -f $fTmp | true
#We check "temp_101.bufr". The path is
#hardcoded in the example
REDIRECT=/dev/null
#Write the key values into a file
${examples_dir}/f_bufr_read_temp #2> $REDIRECT > $fTmp
#TODO: check the results
#cat $fTmp
#Clean up
rm -f $fTmp | true

View File

@ -46,6 +46,7 @@ list( APPEND tests
bufr_keys_iterator
bufr_print_header
bufr_print_data
bufr_read_temp
bufr_set_keys
bufr_subset
get_product_kind

View File

@ -4,7 +4,7 @@ AM_CFLAGS = @WARN_PEDANTIC@ @WERROR@
TESTS = clone.sh count_messages.sh get.sh index.sh iterator.sh keys_iterator.sh multi_write.sh nearest.sh print_data.sh \
samples.sh set.sh set_missing.sh binary_message.sh set_bitmap.sh bufr_print_header.sh bufr_print_data.sh \
bufr_clone.sh bufr_get_keys.sh bufr_set_keys.sh bufr_expanded.sh bufr_keys_iterator.sh bufr_subset.sh \
bufr_attributes.sh get_product_kind.sh
bufr_attributes.sh get_product_kind.sh bufr_read_temp.sh
TESTS_ENVIRONMENT = TOPBUILDDIR=$(top_builddir) PYTHON=$(PYTHON)
noinst_PROGRAMS = p_keys_iterator p_print_data p_iterator p_count_messages
@ -20,6 +20,6 @@ EXTRA_DIST = $(TESTS) include.sh clone.py count_messages.py get.py index.py iter
nearest.py print_data.py samples.py set.py set_missing.py binary_message.py set_pv.py set_bitmap.py \
bufr_print_header.py bufr_print_data.py bufr_clone.py bufr_get_keys.py bufr_set_keys.py \
bufr_expanded.py bufr_keys_iterator.py bufr_subset.py bufr_attributes.py \
get_product_kind.py \
get_product_kind.py bufr_read_temp.py \
CMakeLists.txt include.ctest.sh.in
endif

View File

@ -0,0 +1,128 @@
# Copyright 2005-2015 ECMWF.
#
# This software is licensed under the terms of the Apache Licence Version 2.0
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
#
# In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
# virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
#
# Python implementation: bufr_read_temp
#
# Description: how to read temperature significant levels from TEMP BUFR messages.
#
#
import traceback
import sys
from eccodes import *
INPUT='../../data/bufr/temp_101.bufr'
VERBOSE=1 # verbose error reporting
def example():
# open bufr file
f = open(INPUT)
cnt=0
# loop for the messages in the file
while 1:
# get handle for message
gid = codes_bufr_new_from_file(f)
if gid is None: break
print "message: %s" % cnt
# we need to instruct ecCodes to expand all the descriptors
# i.e. unpack the data values
codes_set(gid,'unpack',1);
# In what follows we rely on the fact that for
# temperature significant levels the value of key
# verticalSoundingSignificance is 4 (see flag table 8001 for details).
# We also make use of the fact that in our BUFR message
# verticalSoundingSignificance is always followed by geopotential,
# airTemperature, dewpointTemperature,
# windDirection, windSpeed and pressure.
#-------------------------------------------------------
# Get the number of the temperature significant levels.
#------------------------------------------------------
# We find out the number of temperature significant levels by
# counting how many pressure values we have on these levels.
numSigT=codes_get_size(gid,"/verticalSoundingSignificance=4/pressure")
print ' Number of temperature significant levels %ld' % (numSigT)
# ----------------------------
# Get pressure
# ----------------------------
sigt_pres=codes_get_array(gid,"/verticalSoundingSignificance=4/pressure")
#--------------------------------
# Get gepotential
#--------------------------------
sigt_geo=codes_get_array(gid,"/verticalSoundingSignificance=4/geopotential")
if len(sigt_geo) != sigTNum :
print "inconstitent number of geopotential values found!"
return 1
#--------------------------------
# Get temperature
#--------------------------------
sigt_t=codes_get_array(gid,"/verticalSoundingSignificance=4/airTemperature")
if len(sigt_t) != sigTNum :
print "inconstitent number of temprature values found!"
return 1
#--------------------------------
# Get dew point
#--------------------------------
sigt_td=codes_get_array(gid,"/verticalSoundingSignificance=4/dewpointTemperature")
if len(sigt_td) != sigTNum :
print "inconstitent number of dewpoint temperature values found!"
return 1
#------------------------------------
# Print the values
# -----------------------------------
print "lev pres geo t td"
print "-------------------------------"
for i in xrange(sigTNum):
print "%3d %6.0f %6.0f %.1f %.1f" % (i+1,sigt_pres[i],sigt_geo[i],sigt_t[i],sigt_td[i])
cnt+=1
# delete handle
codes_release(gid)
# close the file
f.close()
def main():
try:
example()
except CodesInternalError,err:
if VERBOSE:
traceback.print_exc(file=sys.stderr)
else:
print >>sys.stderr,err.msg
return 1
if __name__ == "__main__":
sys.exit(main())

View File

@ -0,0 +1,34 @@
#!/bin/sh
# Copyright 2005-2015 ECMWF.
#
# This software is licensed under the terms of the Apache Licence Version 2.0
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
#
# In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
# virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
#
. ./include.sh
#Define a common label for all the tmp files
label="bufr_read_temp_p"
#Define tmp file
fTmp=${label}.tmp.txt
rm -f $fTmp | true
#We check "temp_101.bufr". The path is
#hardcoded in the example
REDIRECT=/dev/null
#Write the key values into a file
$PYTHON bufr_read_temp.py #2> $REDIRECT > $fTmp
#TODO: check the results
#cat $fTmp
#Clean up
rm -f $fTmp | true