NCEPLIBS-g2c  1.7.0
pdstemplates.c File Reference

Functions for GRIB2 Product Definition Templates used in Section 4 - the Product Definition Section (PDS). More...

#include <stdlib.h>
#include "grib2_int.h"

Go to the source code of this file.

Macros

#define MAXPDSMAPLEN   200
 Maximum template map length. More...
 
#define MAXPDSTEMP   47
 Maximum number of templates. More...
 

Functions

gtemplateextpdstemplate (g2int number, g2int *list)
 This subroutine generates the remaining octet map for a given Product Definition Template, if required. More...
 
static g2int getpdsindex (g2int number)
 This function returns the index of specified Product Definition Template in array templates. More...
 
gtemplategetpdstemplate (g2int number)
 This subroutine returns PDS template information for a specified Product Definition Template. More...
 

Variables

static const struct pdstemplate templatespds [MAXPDSTEMP]
 Data for struct for PDS template. More...
 

Detailed Description

Functions for GRIB2 Product Definition Templates used in Section 4 - the Product Definition Section (PDS).

Each Template has three parts:

  1. The number of entries in the template (mappdslen).
  2. A map of the template (mappds), which contains the number of octets in which to pack each of the template values.
  3. A logical value (needext) that indicates whether the Template needs to be extended. In some cases the number of entries in a template can vary depending upon values specified in the "static" part of the template. (See Template 4.3 as an example).
Note
Array mappds contains the number of octets in which the corresponding template values will be stored. A negative value in mappds is used to indicate that the corresponding template entry can contain negative values. This information is used later when packing (or unpacking) the template data values. Negative data values in GRIB are stored with the left most bit set to one, and a negative number of octets value in mappds[] indicates that this possibility should be considered. The number of octets used to store the data value in this case would be the absolute value of the negative value in mappds.

Program History Log

Date Programmer Comments
2001-06-28 Gilbert Initial
2009-01-14 Vuong Changed structure name template to gtemplate
2009-12-15 Vuong Added Product Definition Templates 4.31, 4.15
2010-08-03 Vuong Added Product Definition Template 4.42 and 4.43
2010-12-08 Vuong Corrected Product Definition Template 4.42 and 4.43
2012-03-29 Vuong Added Templates 4.44,4.45,4.46,4.47,4.48,4.50, 4.51,4.91,4.32 and 4.52
2013-08-05 Vuong Corrected 4.91 and added Templates 4.33,4.34,4.53,4.54
2015-10-07 Vuong Added Templates 4.57, 4.60, 4.61 and allow a forecast time to be negative
Author
Stephen Gilbert
Date
2001-06-28

Definition in file pdstemplates.c.

Macro Definition Documentation

◆ MAXPDSMAPLEN

#define MAXPDSMAPLEN   200

Maximum template map length.

Definition at line 45 of file pdstemplates.c.

◆ MAXPDSTEMP

#define MAXPDSTEMP   47

Maximum number of templates.

Definition at line 44 of file pdstemplates.c.

Function Documentation

◆ extpdstemplate()

gtemplate* extpdstemplate ( g2int  number,
g2int list 
)

This subroutine generates the remaining octet map for a given Product Definition Template, if required.

Some Templates can vary depending on data values given in an earlier part of the Template, and it is necessary to know some of the earlier entry values to generate the full octet map of the Template.

This function allocates memory in the ext field of the gtemplate struct. This memory must be freed by the caller.

Parameters
numbernumber of the Product Definition Template 4.NN that is being requested.
listThe list of values for each entry in the the Product Definition Template.
Returns
Pointer to the returned template struct. Returns NULL pointer if template not found.
Author
Stephen Gilbert
Date
2000-05-11

Definition at line 329 of file pdstemplates.c.

References getpdsindex(), and getpdstemplate().

Referenced by g2_addfield(), and g2_unpack4().

◆ getpdsindex()

static g2int getpdsindex ( g2int  number)
static

This function returns the index of specified Product Definition Template in array templates.

Parameters
numberThe number of the Product Definition Template that is being requested.
Returns
Index of PDT in array templates, if template exists. -1, otherwise.
Author
Stephen Gilbert
Date
2001-06-28

Definition at line 246 of file pdstemplates.c.

References MAXPDSTEMP, and templatespds.

Referenced by extpdstemplate(), and getpdstemplate().

◆ getpdstemplate()

gtemplate* getpdstemplate ( g2int  number)

This subroutine returns PDS template information for a specified Product Definition Template.

The number of entries in the template is returned along with a map of the number of octets occupied by each entry. Also, a flag is returned to indicate whether the template would need to be extended.

This function allocates memory for the gtemplate struct, which must be freed by the caller.

Parameters
numberthe number of the Product Definition Template that is being requested.
Returns
Pointer to the returned template struct. Returns NULL pointer if template not found.
Author
Stephen Gilbert
Date
2000-05-11

Definition at line 281 of file pdstemplates.c.

References getpdsindex(), and templatespds.

Referenced by extpdstemplate(), g2_addfield(), and g2_unpack4().

Variable Documentation

◆ templatespds

const struct pdstemplate templatespds[MAXPDSTEMP]
static

Data for struct for PDS template.

Definition at line 61 of file pdstemplates.c.

Referenced by getpdsindex(), and getpdstemplate().