BAG --- Bathymetry Attributed Grid
This driver provides read-only support, and starting with GDAL 2.4 for creation,
for bathymetry data in the BAG format.
BAG files are actually a specific product profile in an HDF5 file, but a
custom driver exists to present the data in a more convenient manner than
is available through the generic HDF5 driver.
BAG files have two or three image bands representing Elevation (band 1),
Uncertainty (band 2) and Nominal Elevation (band 3) values for each cell in a
raster grid area.
The geotransform and coordinate system is extracted from the internal XML
metadata provided with the dataset. However, some products may have
unsupported coordinate system formats, if using the non-WKT way of encoding
the spatial reference system.
The full XML metadata is available in the "xml:BAG" metadata domain.
Nodata, minimum and maximum values for each band are also reported.
Variable resolution (VR) grid support
Starting with GDAL 2.4, GDAL can handle BAG files with
variable resolution grids. Such datasets are made of a low-resolution grid,
which is the one presented by default by the driver, and for each of those
low-resolution cells, a higher resolution grid can be present in the file.
Such higher resolution grids are dubbed "supergrids" in GDAL.
The driver has different modes of working which can be controlled by the
MODE open option:
Creation support
Starting with GDAL 2.4, the driver can create a BAG dataset (without variable
resolution extension) with the elevation and uncertainty bands from a source
dataset. The source dataset must be georeferenced, and have one or two bands.
The first band is assumed to be the elevation band, and the second band the
uncertainty band. If the second band is missing, the uncertainty will be set to
nodata.
The driver will instantiate the BAG XML metadata by using a template file,
which is by default,
bag_template.xml, found in the GDAL data definition files. This template
contains variables, present as ${KEYNAME} or ${KEYNAME:default_value} in the
XML file, that can be substituted by providing a creation option whose name is
the VAR_ string prefixed to the key name. Currently those creation options are:
- VAR_INDIVIDUAL_NAME=string: to fill contact/CI_ResponsibleParty/individualName.
If not provided, default to "unknown".
- VAR_ORGANISATION_NAME=string: to fill contact/CI_ResponsibleParty/organisationName.
If not provided, default to "unknown".
- VAR_POSITION_NAME=string: to fill contact/CI_ResponsibleParty/positionName.
If not provided, default to "unknown".
- VAR_DATE=YYYY-MM-DD: to fill dateStamp/Date. If not provided, default to
current date.
- VAR_VERT_WKT=wkt_string: to fill referenceSystemInfo/MD_ReferenceSystem/referenceSystemIdentifier/RS_Identifier/code
for the vertical coordinate reference system. If not provided, and if the
input CRS is not a compound CRS, default to
VERT_CS["unknown", VERT_DATUM["unknown", 2000]].
- VAR_ABSTRACT=string: to fill identificationInfo/abstract. If not provided,
default to empty string
- VAR_PROCESS_STEP_DESCRIPTION=string: to fill dataQualityInfo/lineage/LI_Lineage/processStep/LI_ProcessStep/description.
If not provided, default to "Generated by GDAL x.y.z".
- VAR_DATETIME=YYYY-MM-DDTHH:MM:SS : to fill dataQualityInfo/lineage/LI_Lineage/processStep/LI_ProcessStep/dateTime/DateTime.
If not provided, default to current datetime.
- VAR_RESTRICTION_CODE=enumerated_value: to fill metadataConstraints/MD_LegalConstraints/useConstraints/MD_RestrictionCode.
If not provided, default to "otherRestrictions".
- VAR_OTHER_CONSTRAINTS=string: to fill metadataConstraints/MD_LegalConstraints/otherConstraints.
If not provided, default to "unknown".
- VAR_CLASSIFICATION=enumerated_value: to fill metadataConstraints/MD_SecurityConstraints/classification/MD_ClassificationCode.
If not provided, default to "unclassified".
- VAR_SECURITY_USER_NOTE=string: to fill metadataConstraints/MD_SecurityConstraints/userNote.
If not provided, default to "none".
Other required variables found in the template, such as RES, RESX, RESY,
RES_UNIT, HEIGHT, WIDTH, CORNER_POINTS and HORIZ_WKT will be automatically
filled from the input dataset metadata.
The other following creation options are available:
- TEMPLATE=filename: Path to a XML file that can serve as a template. This
will typically be a customized version of the base bag_template.xml file. The
file can contain other substituable variables than the ones mentioned above
by using a similar syntax.
- VAR_xxxx=value: Substitute variable ${xxxx} in the template XML value by
the provided value.
- BAG_VERSION=string: Value to write in the /BAG_root/BAG Version attribute.
Default to 1.6.2.
- COMPRESS=NONE/DEFLATE: Compression for elevation and uncertainty grids. Default
to DEFLATE.
- ZLEVEL=[1-9]: Deflate compression level. Defaults to 6.
- BLOCK_SIZE=value_in_pixel: Chunking size of the HDF5 arrays. Default to 100,
or the maximum dimension of the raster if smaller than 100.
Usage examples
- Opening in low resolution mode:
$ gdalinfo data/test_vr.bag
[...]
Size is 6, 4
[...]
  HAS_SUPERGRIDS=TRUE
  MAX_RESOLUTION_X=29.900000
  MAX_RESOLUTION_Y=31.900000
  MIN_RESOLUTION_X=4.983333
  MIN_RESOLUTION_Y=5.316667
[...]
 
- Displaying available supergrids:
$ gdalinfo data/test_vr.bag -oo MODE=LIST_SUPERGRIDS
[...]
Subdatasets:
  SUBDATASET_1_NAME=BAG:"data/test_vr.bag":supergrid:0:0
  SUBDATASET_1_DESC=Supergrid (y=0, x=0) from (x=70.100000,y=499968.100000) to (x=129.900000,y=500031.900000), resolution (x=29.900000,y=31.900000)
  SUBDATASET_2_NAME=BAG:"data/test_vr.bag":supergrid:0:1
  SUBDATASET_2_DESC=Supergrid (y=0, x=1) from (x=107.575000,y=499976.075000) to (x=152.424999,y=500023.924999), resolution (x=14.950000,y=15.950000)
[...]
  SUBDATASET_24_NAME=BAG:"data/test_vr.bag":supergrid:3:5
  SUBDATASET_24_DESC=Supergrid (y=3, x=5) from (x=232.558335,y=500077.391667) to (x=267.441666,y=500114.608334), resolution (x=4.983333,y=5.316667)
[...]
 
- Opening a particular supergrid:
$ gdalinfo BAG:"data/test_vr.bag":supergrid:3:5
 
- Converting a BAG in resampling mode with default parameters (use of
minimum resolution of supergrids, MAX value population rule, no interpolation):
$ gdal_translate data/test_vr.bag -oo MODE=RESAMPLED_GRID out.tif
 
- Converting a BAG in resampling mode with a particular grid origin and resolution
$ gdal_translate data/test_vr.bag -oo MODE=RESAMPLED_GRID -oo MINX=80 -oo MINY=500000 -oo RESX=16 -oo RESY=16 out.tif
 
- Converting a BAG in resampling mode, with a mask indicating where supergrids
nodes intersect the cell of the resampled dataset.
$ gdal_translate data/test_vr.bag -oo MODE=RESAMPLED_GRID -oo SUPERGRIDS_MASK=YES out.tif
 
- Converting a BAG in resampling mode, with interpolation of nodata values.
$ gdal_translate data/test_vr.bag -oo MODE=RESAMPLED_GRID -oo INTERPOLATION=INVDIST out.tif
 
- Converting a BAG in resampling mode, by filtering on supergrid resolutions
(and the resampled grid will use 4 meter resolution by default)
$ gdal_translate data/test_vr.bag -oo MODE=RESAMPLED_GRID -oo RES_FILTER_MIN=4 -oo RES_FILTER_MAX=8 out.tif
 
- Converting a GeoTIFF file to a BAG dataset, and provide a custom value for the ABSTRACT substituable variable.
$ gdal_translate in.tif out.bag -co "VAR_ABSTRACT=My abstract"
 
- Converting a (VR) BAG in resampling mode with a particular grid
resolution (5m) to a BAG dataset (without variable resolution extension),
and provide a custom value for the ABSTRACT metadata:
$ gdal_translate data/test_vr.bag -oo MODE=RESAMPLED_GRID -oo RESX=5 -oo RESY=5 out.bag -co "VAR_ABSTRACT=My abstract"
 
See Also: