Skip Navigation Links www.nws.noaa.gov 
NOAA logo - Click to go to the NOAA home page National Weather Service   NWS logo - Click to go to the NWS home page
Climate Prediction Center
 
 

 
About Us
   Our Mission
   Who We Are

Contact Us
   CPC Information
   CPC Web Team

 
HOME > Monitoring_and_Data > Oceanic and Atmospheric Data > Reanalysis: Atmospheric Data > wgrib2-g2clib
 

wgrib2: -g2clib

Introduction

Originally wgrib2 used the g2clib library for unpacking the grid point data (GDS). The first break from a complete dependence on the g2clib was adding support for ieee-type grib files. Then the optimized grib1-style unpacking from wgrib was added to the internal routines. Then jpeg, png and complex packing were added to the internal decoder. Finally more packing schemes that were not in g2lib/g2clib were added (run-length and log scaling).

As of wgrib2 v1.9.8, a third option was added, use the internal decoder in g2clib emulation mode. The options were also relabeled. The new default is to use the internal decoder in g2clib emulation mode (-g2clib 1). To use use the internal decoder you still use -g2clib 0. To get the g2clib decoder, use -g2clib 2 which is now a compile-time option. The changes were made because

  1. internal routines are faster for complex packing (1 cpu)
  2. some internal routines were parallelized for decoding (complex and simple packing)
  3. some distributions were linking the official g2clib rather than the patched version included with the wgrib2 sources. This caused seg faults.

Wgrib2 has always used its own routines for encoding grib files. The encoding follows the WMO standard but are compatible with the NCEP libraries (g2clib and g2lib).

Differences as of October 2008

The NCEP encoding/decoding routines have a problem with constant fields. The routines ignore the decimal scaling and assume it is zero (decimal scaling = multiplication by one). The packing and unpacking routines are are consistent with themselves so the problem wasn't noticed for many years. As of 6/2014 this situation hasn't changed. This same bug has been found in routine in other software packages. Some are consistently ignore the decimal scaling for all packing modes, whereas others only have the bug for certain packing modes. By the use of "-g2clib 0" and "-g2clib 1", you can handle grib files without/with this bug.

The wgrib2 internal decode routines do not have a decimal scaling problem and follow the WMO standard. The wgrib2 encode routines will automatically use a decimal scaling = 0 for constant fields and consequently be compatible with the WMO standard and will decode correcty with g2clib/g2lib.

The g2clib emulation (default, -g2clib 1) are recommend when

  1. The files were created by using g2clib/g2lib libraries (NCEP) and have the bug
    The files must must have the center set to NCEP
  2. files that were encoded using wgrib2 (more than simple subsetting)
  3. WMO-compliant files from centers other than NCEP
Turning off the g2clib emulation (-g2clib 0) is recommend when
  1. grib files that follow WMO standard for constant fields
Finally one potentially compile wgrib2 to include g2clib. This is useful for testing and for cases where g2clib supports a packing that is not supported by the internal decoder. The disadvantages of the g2clib routines are
  1. Single precision routines
  2. The routines are slower for large grids and they are not threaded
  3. The g2clib routines "fail" when they finds an undefined template.
  4. Decoding problems with certain fields (6/2016).
  5. Problems with seg faults when linked with the official g2clib (Fedora/Redhat rpms)

-g2clib

The -g2clib option allows you to select the internal/g2clib decoder. If X is 0, then internal routines are selected. If X is 1, then the internal decoder with g2clib emulation is selected (g2clib is used with older wgrib2 versions). When X is 2, then the g2clib decoder is used if the g2clib decoder were compiled into the executable. Note that g2clib doesn't support ieee, RLE, AEC and irregular structured grids.

Usage

-g2clib N   N = 0, 1 or 2
            0 = WMO standard (for all files)
            1 = default
	        emulate NCEP g2/g2c bug for decoding constant values fields for
	        files from NCEP (center=NCEP (7))
		Files not from NCEP are unaffected
            2 = use g2clib, only available if compiled with g2clib
                This option should only be used for testing.
                Some distributions will seg fault using this option.
		Files from non-NCEP sources may have the wrong constant values

NOAA/ National Weather Service
National Centers for Environmental Prediction
Climate Prediction Center
5830 University Research Court
College Park, Maryland 20740
Climate Prediction Center Web Team
Page last modified: Aug 19, 2016, July 2024
Disclaimer Privacy Policy