Tabs Page |
---|
| Code Block |
---|
language | cpp |
---|
title | bufr_read_temp.c |
---|
linenumbers | false |
---|
| /*
* 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.
*/
/*
* C Implementation: bufr_read_temp
*
* Description: how to read temperature significant levels from TEMP BUFR messages.
*
*/
#include "eccodes.h"
int main(int argc,char* argv[])
{
FILE* in = NULL;
/* message handle. Required in all the eccodes calls acting on a message.*/
codes_handle* h=NULL;
char* units= NULL;
char* unitsPercent= NULL;
double *sigt_pres=NULL, *sigt_geo=NULL, *sigt_t=NULL;
double *sigt_td=NULL;
long longVal;
double doubleVal;
size_t sigt_len=0, desc_len=0, len=0;
int i, err=0;
int cnt=0;
char* infile = "../../data/bufr/temp_101.bufr";
char key_name[128];
in=fopen(infile,"r");
if (!in) {
printf("ERROR: unable to open file %s\n", infile);
return 1;
}
/* loop over the messages in the bufr file */
while ((h = codes_handle_new_from_file(NULL,in,PRODUCT_BUFR,&err)) != NULL || err != CODES_SUCCESS)
{
if (h == NULL) {
printf("Error: unable to create handle for message %d\n",cnt/*
* Please note that TEMP reports can be encoded in various ways in BUFR. Therefore the code
* below might not work directly for other types of SYNOP messages than the one used in the
* example. It is advised to use bufr_dump to understand the structure of the messages.
*/
#include "eccodes.h"
int main(int argc,char* argv[])
{
FILE* in = NULL;
/* Message handle. Required in all the eccodes calls acting on a message.*/
codes_handle* h=NULL;
double *sigt_pres=NULL, *sigt_geo=NULL, *sigt_t=NULL;
double *sigt_td=NULL;
long longVal;
double doubleVal;
size_t sigt_len=0, desc_len=0, len=0;
int i, err=0;
int cnt=0;
char* infile = "../../data/bufr/temp_101.bufr";
char key_name[128];
in=fopen(infile,"r");
if (!in) {
printf("ERROR: unable to open file %s\n", infile);
cnt++return 1;
}
/* Loop over the continue;
messages in the bufr }
file */
while ((h printf("message: %d\n",cnt);
/* we need to instruct ecCodes to expand the descriptors
= codes_handle_new_from_file(NULL,in,PRODUCT_BUFR,&err)) != NULL || err != CODES_SUCCESS)
{
if (h == NULL) {
i.e. unpack the data values */
CODES_CHECK(codes_set_long(h,"unpack",1),0);
printf("Error: unable to create handle for message %d\n",cnt);
/* In what follows we rely on the fact that for
cnt++;
continue;
temperature significant levels the value of key}
verticalSoundingSignificance is 4 (see flag table 8001 for details).printf("message: %d\n",cnt);
/* We need Weto alsoinstruct makeecCodes useto ofexpand the fact that in our BUFR messagedescriptors
verticalSoundingSignificance is always followed by geopotential,i.e. unpack the data values */
airTemperature, dewpointTemperature,
CODES_CHECK(codes_set_long(h,"unpack",1),0);
/* In what windDirection,follows windSpeedwe andrely pressure. */
on the fact that for
/* Get the number of* the temperature significant levels.*/
the value of key
/* We find out the number* ofverticalSoundingSignificance temperatureis significant4 levels(see by
flag table 8001 for details).
counting how *
many pressure values we have on these levels. */
In our BUFR message verticalSoundingSignificance is sprintf(key_name,"/verticalSoundingSignificance=4/pressure");
always followed by
* CODES_CHECK(codes_get_size(h,key_name,&sigt_len),0);
geopotential, airTemperature, dewpointTemperature,
printf("Number of* T significant levels: %ld\n",sigt_len);
windDirection, windSpeed and pressure.
/* Allocate memory for the values* So in order to access any of these keys we need to beuse read.the
Each
* condition: verticalSoundingSignificance=4.
parameter must have the same number of values. */
sigt_pres = malloc(sigt_len*sizeof(double));/* Get the number of the temperature significant levels.*/
sigt_geo = malloc(sigt_len*sizeof(double));
sigt_t = malloc(sigt_len*sizeof(double));/* We find out the number of temperature significant levels by
sigt_td = malloc(sigt_len*sizeof(double));
/* Get pressure */
* counting how many pressure values we have on these levels.*/
sprintf(key_name,"/verticalSoundingSignificance=4/pressure");
/* get the values */
len=sigt_len;
CODES_CHECK(codes_get_double_arraysize(h,key_name,&sigt_pres,&len),0);
/* Get geopotential */
sprintf(key_name,"/verticalSoundingSignificance=4/geopotential"printf("Number of T significant levels: %ld\n",sigt_len);
/* Allocate checkmemory for the size*/
values to be read. Each
CODES_CHECK(codes_get_size(h,key_name,&len),0);
* parameter must if(len != sigt_len)
{have the same number of values. */
sigt_pres printf("inconsistent number of geopotential values found!\n"= malloc(sigt_len*sizeof(double));
sigt_geo return 1= malloc(sigt_len*sizeof(double));
}
/* get the values */
sigt_t = malloc(sigt_len*sizeof(double));
sigt_td = CODES_CHECK(codes_get_double_array(h,key_name,sigt_geo,&len),0malloc(sigt_len*sizeof(double));
/* Get temperaturepressure */
sprintf(key_name,"/verticalSoundingSignificance=4/airTemperaturepressure");
/* checkGet the values size*/
if(len != sigt_len);
{
CODES_CHECK(codes_get_double_array(h,key_name,sigt_pres,&len),0);
/* Get geopotential */
printf("inconsistent number of temperature values found!\n sprintf(key_name,"/verticalSoundingSignificance=4/geopotential");
/* Check return 1;the size*/
}
/* get the values */
CODES_CHECKCODES_CHECK(codes_get_double_arraysize(h,key_name,sigt_t,&len),0);
/* Get dew point */if(len != sigt_len)
sprintf(key_name,"/verticalSoundingSignificance=4/dewpointTemperature");
{
/* check the size*/
if(len != sigt_len)
{
printf("inconsistent number of dewpointgeopotential temperature values found!\n");
return 1;
}
/* getGet the values */
CODES_CHECK(codes_get_double_array(h,key_name,sigt_tdgeo,&len),0);
/* PrintGet thetemperature values */
printf("lev pressprintf(key_name,"/verticalSoundingSignificance=4/airTemperature");
geo /* Check t td\n");the size*/
printf("-------------------------------\n");
for(i=0; i < sigt_len; i++if(len != sigt_len)
{
printf("%3d %6.0f %6.0f %.1f %.1finconsistent number of temperature values found!\n",);
i+1,sigt_pres[i],sigt_geo[i],sigt_t[i],sigt_td[i])return 1;
}
/* deleteGet the handlevalues */
CODES_CHECK(codes_handleget_double_deletearray(h),key_name,sigt_t,&len),0);
/*Release memory Get dew point */
freesprintf(sigt_preskey_name,"/verticalSoundingSignificance=4/dewpointTemperature");
free(sigt_geo);/* Check the size*/
freeif(len != sigt_tlen);
free(sigt_td);
{
cnt++;
}
fclose(inprintf("inconsistent number of dewpoint temperature values found!\n");
return 0;
}
|
| Tabs Page |
---|
| Code Block |
---|
language | none |
---|
title | bufr_read_temp.f90 |
---|
linenumbers | false |
---|
| !
!Copyright 2005-2015 ECMWF.
!
! This software is licensed underreturn the1;
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_read_temp
use eccodes
implicit none
integer :: ifile
integer }
/* Get the values */
CODES_CHECK(codes_get_double_array(h,key_name,sigt_td,&len),0);
/* Print the values */
printf("lev pres geo t td\n");
printf("-------------------------------\n");
for(i=0; i < :: iret
integersigt_len; i++)
{
:: ibufr
integer printf("%3d %6.0f %6.0f %.1f :: i, count=0
integer(kind=4)%.1f\n",
:: numSigT
integer(kind=4) :: num
real(kind=8), i+1,sigt_pres[i],sigt_geo[i],sigt_t[i],sigt_td[i]);
}
/* Delete handle */
codes_handle_delete(h);
/* Release memory */
free(sigt_pres);
free(sigt_geo);
free(sigt_t);
free(sigt_td);
cnt++;
}
fclose(in);
return 0;
}
|
|
Tabs Page |
---|
| Code Block |
---|
language | none |
---|
title | bufr_read_temp.f90 |
---|
linenumbers | false |
---|
| !
!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.
!
! Please note that SYNOP reports can be encoded in various ways in BUFR. Therefore the code
! below might not work directly for other types of SYNOP messages than the one used in the
! example. It is advised to bufr_dump to understand the structure of the messages.
program bufr_read_temp
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(:), 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).
!
! In our BUFR message verticalSoundingSignificance is always followed by
! We also make use of the fact that in our BUFR message geopotential, airTemperature, dewpointTemperature,
! windDirection, windSpeed and pressure.
!
! verticalSoundingSignificanceSo isin alwaysorder followedto byaccess geopotential,any
of these keys we ! airTemperature, dewpointTemperature,need to use the
! windDirection, windSpeed and pressure. condition: verticalSoundingSignificance=4.
! ---- 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 exit(1)
codes_get(ibufr,keyName,tdVal) end if
! get---- Print the values --------------------------------
call codes_getwrite(ibufr*,keyName,tdVal) *) 'level pres geo
t td'
! write(*,*) "------- Print the values -----------------------------------"
do i=1,numSigT
write(*,*) i,presVal(i),geoVal(i),tVal(i),tdVal(i)
end do
write(*,*) 'level
pres
geo! free arrays
t td'deallocate(presVal)
writedeallocate(*,*) "--------------------------------------" geoVal)
deallocate(tVal)
deallocate(tdVal)
! do i=1,numSigT release the bufr message
call codes_release(ibufr)
write(*,*) i,presVal(i),geoVal(i),tVal(i),tdVal(i! load the next bufr message
call codes_bufr_new_from_file(ifile,ibufr,iret)
end do
count=count+1
end do
! close file
call ! 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_read_temp
codes_close_file(ifile)
end program bufr_read_temp
|
|
Tabs Page |
---|
| Code Block |
---|
language | python |
---|
title | bufr_read_temp.py |
---|
linenumbers | false |
---|
| # 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.
#
#
# Please note that TEMP reports can be encoded in various ways in BUFR. Therefore the code
# below might not work directly for other types of SYNOP messages than the one used in the
# example. It is advised to use bufr_dump to understand the structure of the messages. |
| Tabs Page |
---|
| Code Block |
---|
language | python |
---|
title | bufr_read_temp.py |
---|
linenumbers | false |
---|
| # 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_double_array(gid,"/verticalSoundingSignificance=4/pressure")
# Get gepotential
sigt_geo=codes_get_double_array(gid,"/verticalSoundingSignificance=4/geopotential")
if len(sigt_geo) != numSigT :
print "inconstitent number of geopotential values found!"
return 1
# Get temperature
sigt_t=codes_get_double_array(gid,"/verticalSoundingSignificance=4/airTemperature")
if len(sigt_t) != numSigT :
print "inconstitent number of temprature values found!"
return 1
# Get dew point
sigt_td=codes_get_double_array(gid,"/verticalSoundingSignificance=4/dewpointTemperature")
if len(sigt_td) != numSigT:
print "inconstitent number of dewpoint temperature values found!"
return 1
# Print the values
print "lev pres geo t td"
print "-------------------------------"
for i in xrange(numSigT):
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())
|
|
|