.. _programs:

================================================================================
Programs
================================================================================

"gdal" application
------------------

Starting with GDAL 3.11, parts of the GDAL utilities are available from a new
single :program:`gdal` program that accepts commands and subcommands.

.. warning::

    The :program:`gdal` command is provisionally provided as an alternative
    interface to GDAL and OGR command line utilities. The project reserves the
    right to modify, rename, reorganize, and change the behavior of the utility
    until it is officially frozen via PSC vote in a future major GDAL release.
    The utility needs time to mature, benefit from incremental feedback, and
    explore enhancements without carrying the burden of full backward compatibility.
    Your usage of it should have no expectation of compatibility until that time.


.. toctree::
   :maxdepth: 1
   :hidden:

   migration_guide_to_gdal_cli
   gdal_cli_from_python
   gdal_cli_gdalg
   gdal
   gdal_info
   gdal_convert
   gdal_driver_gti_create
   gdal_mdim
   gdal_mdim_info
   gdal_mdim_convert
   gdal_raster
   gdal_raster_info
   gdal_raster_aspect
   gdal_raster_calc
   gdal_raster_clean_collar
   gdal_raster_clip
   gdal_raster_color_map
   gdal_raster_contour
   gdal_raster_convert
   gdal_raster_create
   gdal_raster_edit
   gdal_raster_footprint
   gdal_raster_fill_nodata
   gdal_raster_hillshade
   gdal_raster_index
   gdal_raster_mosaic
   gdal_raster_overview
   gdal_raster_overview_add
   gdal_raster_overview_delete
   gdal_raster_pipeline
   gdal_raster_pixel_info
   gdal_raster_polygonize
   gdal_raster_reclassify
   gdal_raster_reproject
   gdal_raster_resize
   gdal_raster_roughness
   gdal_raster_scale
   gdal_raster_select
   gdal_raster_set_type
   gdal_raster_slope
   gdal_raster_sieve
   gdal_raster_stack
   gdal_raster_tile
   gdal_raster_tpi
   gdal_raster_tri
   gdal_raster_unscale
   gdal_raster_viewshed
   gdal_vector
   gdal_vector_info
   gdal_vector_clip
   gdal_vector_concat
   gdal_vector_convert
   gdal_vector_edit
   gdal_vector_filter
   gdal_vector_geom
   gdal_vector_geom_set_type
   gdal_vector_geom_explode_collections
   gdal_vector_geom_make_valid
   gdal_vector_geom_segmentize
   gdal_vector_geom_simplify
   gdal_vector_geom_buffer
   gdal_vector_geom_swap_xy
   gdal_vector_grid
   gdal_vector_pipeline
   gdal_vector_rasterize
   gdal_vector_reproject
   gdal_vector_select
   gdal_vector_sql
   gdal_vsi
   gdal_vsi_copy
   gdal_vsi_delete
   gdal_vsi_list
   gdal_vsi_move
   gdal_vsi_sync
   gdal_vsi_sozip

.. only:: html

    - :ref:`migration_guide_to_gdal_cli`: Migration guide to "gdal" command line interface
    - :ref:`gdal_cli_from_python`: How to use "gdal" CLI algorithms from Python
    - :ref:`gdal_cli_gdalg`: .gdalg files to replay serialized "gdal" commands
    - :ref:`gdal_program`: Main "gdal" entry point
    - :ref:`gdal_info`: Get information on a dataset
    - :ref:`gdal_convert`: Convert a dataset
    - :ref:`gdal_driver_gti_create`: Create an index of raster datasets compatible of the GDAL Tile Index (GTI) driver
    - :ref:`gdal_mdim`: Entry point for multidimensional commands
    - :ref:`gdal_mdim_info`: Get information on a multidimensional dataset
    - :ref:`gdal_mdim_convert`: Convert a multidimensional dataset
    - :ref:`gdal_raster`: Entry point for raster commands
    - :ref:`gdal_raster_info`: Get information on a raster dataset
    - :ref:`gdal_raster_aspect`: Generate an aspect map.
    - :ref:`gdal_raster_calc`: Perform raster algebra
    - :ref:`gdal_raster_clean_collar`: Clean the collar of a raster dataset, removing noise
    - :ref:`gdal_raster_clip`: Clip a raster dataset
    - :ref:`gdal_raster_color_map`: Generate a RGB or RGBA dataset from a single band, using a color map
    - :ref:`gdal_raster_convert`: Convert a raster dataset
    - :ref:`gdal_raster_contour`: Builds vector contour lines from a raster elevation model
    - :ref:`gdal_raster_create`: Create a new raster dataset
    - :ref:`gdal_raster_edit`: Edit in place a raster dataset
    - :ref:`gdal_raster_footprint`: Compute the footprint of a raster dataset.
    - :ref:`gdal_raster_fill_nodata`: Fill raster regions by interpolation from edges.
    - :ref:`gdal_raster_hillshade`: Generate a shaded relief map
    - :ref:`gdal_raster_index`: Create a vector index of raster datasets
    - :ref:`gdal_raster_mosaic`: Build a mosaic, either virtual (VRT) or materialized.
    - :ref:`gdal_raster_overview`: Manage overviews of a raster dataset
    - :ref:`gdal_raster_overview_add`: Add overviews to a raster dataset
    - :ref:`gdal_raster_overview_delete`: Remove overviews of a raster dataset
    - :ref:`gdal_raster_pipeline`: Process a raster dataset
    - :ref:`gdal_raster_polygonize`: Create a polygon feature dataset from a raster band
    - :ref:`gdal_raster_pixel_info`: Return information on a pixel of a raster dataset
    - :ref:`gdal_raster_reclassify`: Reclassify a raster dataset
    - :ref:`gdal_raster_reproject`: Reproject a raster dataset
    - :ref:`gdal_raster_resize`: Resize a raster dataset without changing the georeferenced extents
    - :ref:`gdal_raster_roughness`: Generate a roughness map.
    - :ref:`gdal_raster_scale`: Scale the values of the bands of a raster dataset.
    - :ref:`gdal_raster_select`: Select a subset of bands from a raster dataset.
    - :ref:`gdal_raster_set_type`: Modify the data type of bands of a raster dataset
    - :ref:`gdal_raster_sieve`: Remove small raster polygons.
    - :ref:`gdal_raster_slope`: Generate a slope map.
    - :ref:`gdal_raster_stack`: Combine together input bands into a multi-band output, either virtual (VRT) or materialized.
    - :ref:`gdal_raster_tile`: Generate tiles in separate files from a raster dataset.
    - :ref:`gdal_raster_tpi`: Generate a Topographic Position Index (TPI) map.
    - :ref:`gdal_raster_tri`: Generate a Terrain Ruggedness Index (TRI) map.
    - :ref:`gdal_raster_unscale`: Convert scaled values of a raster dataset into unscaled values.
    - :ref:`gdal_raster_viewshed`: Compute the viewshed of a raster dataset.
    - :ref:`gdal_vector`: Entry point for vector commands
    - :ref:`gdal_vector_info`: Get information on a vector dataset
    - :ref:`gdal_vector_clip`: Clip a vector dataset
    - :ref:`gdal_vector_concat`: Concatenate vector datasets
    - :ref:`gdal_vector_convert`: Convert a vector dataset
    - :ref:`gdal_vector_edit`: Edit metadata of a vector dataset
    - :ref:`gdal_vector_filter`: Filter a vector dataset
    - :ref:`gdal_vector_geom`: Geometry operations on a vector dataset
    - :ref:`gdal_vector_geom_set_type`: Modify the geometry type of a vector dataset
    - :ref:`gdal_vector_geom_explode_collections`: Explode geometries of type collection of a vector dataset
    - :ref:`gdal_vector_geom_make_valid`: Fix validity of geometries of a vector dataset
    - :ref:`gdal_vector_geom_segmentize`: Segmentize geometries of a vector dataset
    - :ref:`gdal_vector_geom_simplify`: Simplify geometries of a vector dataset
    - :ref:`gdal_vector_geom_buffer`: Compute a buffer around geometries of a vector dataset
    - :ref:`gdal_vector_geom_swap_xy`: Swap X and Y coordinates of geometries of a vector dataset
    - :ref:`gdal_vector_grid`: Create a regular grid from scattered points
    - :ref:`gdal_vector_convert`: Convert a vector dataset
    - :ref:`gdal_vector_pipeline`: Process a vector dataset
    - :ref:`gdal_vector_reproject`: Reproject a vector dataset
    - :ref:`gdal_vector_select`: Select a subset of fields from a vector dataset.
    - :ref:`gdal_vector_rasterize`: Burns vector geometries into a raster
    - :ref:`gdal_vector_sql`: Apply SQL statement(s) to a dataset
    - :ref:`gdal_vsi`: Entry point for GDAL Virtual System Interface (VSI) commands
    - :ref:`gdal_vsi_copy`: Copy files located on GDAL Virtual System Interface (VSI)
    - :ref:`gdal_vsi_delete`: Delete files located on GDAL Virtual System Interface (VSI)
    - :ref:`gdal_vsi_list`: List files of one of the GDAL Virtual System Interface (VSI)
    - :ref:`gdal_vsi_move`: Move/rename a file/directory located on GDAL Virtual System Interface (VSI)
    - :ref:`gdal_vsi_sync`: Synchronize source and target file/directory located on GDAL Virtual System Interface (VSI)
    - :ref:`gdal_vsi_sozip`: SOZIP (Seek-Optimized ZIP) related commands


"Traditional" applications
--------------------------

General
+++++++

.. toctree::
   :maxdepth: 1
   :hidden:

   argument_syntax

.. only:: html

    - :ref:`argument_syntax`


Raster programs
+++++++++++++++

.. toctree::
   :maxdepth: 1
   :hidden:

   Common options <raster_common_options>

   gdal-config
   gdal2tiles
   gdal2xyz
   gdal_calc
   gdal_contour
   gdal_create
   gdal_edit
   gdal_fillnodata
   gdal_footprint
   gdal_grid
   gdal_merge
   gdal_pansharpen
   gdal_polygonize
   gdal_proximity
   gdal_rasterize
   gdal_retile
   gdal_sieve
   gdal_translate
   gdal_viewshed
   gdaladdo
   gdalattachpct
   gdalbuildvrt
   gdalcompare
   gdaldem
   gdalenhance
   gdalinfo
   gdallocationinfo
   gdalmanage
   gdalmove
   gdalsrsinfo
   gdaltindex
   gdaltransform
   gdalwarp
   nearblack
   pct2rgb
   rgb2pct

.. only:: html

    - :ref:`Common options <raster_common_options>`
    - :ref:`gdal-config`: Determines various information about a GDAL installation.
    - :ref:`gdal2tiles`: Generates directory with TMS tiles, KMLs and simple web viewers.
    - :ref:`gdal2xyz`: Translates a raster file into xyz format.
    - :ref:`gdal_calc`: Command line raster calculator with numpy syntax.
    - :ref:`gdal_contour`: Builds vector contour lines from a raster elevation model.
    - :ref:`gdal_create`: Create a raster file (without source dataset).
    - :ref:`gdal_edit`: Edit in place various information of an existing GDAL dataset.
    - :ref:`gdal_fillnodata`: Fill raster regions by interpolation from edges.
    - :ref:`gdal_footprint`: Compute footprint of a raster.
    - :ref:`gdal_grid`: Creates regular grid from the scattered data.
    - :ref:`gdal_merge`: Mosaics a set of images.
    - :ref:`gdal_pansharpen`: Perform a pansharpen operation.
    - :ref:`gdal_polygonize`: Produces a polygon feature layer from a raster.
    - :ref:`gdal_proximity`: Produces a raster proximity map.
    - :ref:`gdal_rasterize`: Burns vector geometries into a raster.
    - :ref:`gdal_retile`: Retiles a set of tiles and/or build tiled pyramid levels.
    - :ref:`gdal_sieve`: Removes small raster polygons.
    - :ref:`gdal_translate`: Converts raster data between different formats.
    - :ref:`gdal_viewshed`: Compute a visibility mask for a raster.
    - :ref:`gdaladdo`: Builds or rebuilds overview images.
    - :ref:`gdalattachpct`: Attach a color table to a raster file from an input file.
    - :ref:`gdalbuildvrt`: Builds a VRT from a list of datasets.
    - :ref:`gdalcompare`: Compare two images.
    - :ref:`gdaldem`: Tools to analyze and visualize DEMs.
    - :ref:`gdalenhance`: Enhance an image with LUT-based contrast enhancement
    - :ref:`gdalinfo`: Lists information about a raster dataset.
    - :ref:`gdallocationinfo`: Raster query tool
    - :ref:`gdalmanage`: Identify, delete, rename and copy raster data files.
    - :ref:`gdalmove`: Transform georeferencing of raster file in place.
    - :ref:`gdalsrsinfo`: Lists info about a given SRS in number of formats (WKT, PROJ.4, etc.)
    - :ref:`gdaltindex`: Builds an OGR-supported dataset as a raster tileindex.
    - :ref:`gdaltransform`: Transforms coordinates.
    - :ref:`gdalwarp`: Image reprojection and warping utility.
    - :ref:`nearblack`: Convert nearly black/white borders to black.
    - :ref:`pct2rgb`: Convert an 8bit paletted image to 24bit RGB.
    - :ref:`rgb2pct`: Convert a 24bit RGB image to 8bit paletted.

Multidimensional Raster programs
++++++++++++++++++++++++++++++++

.. toctree::
   :maxdepth: 1
   :hidden:

   gdalmdiminfo
   gdalmdimtranslate

.. only:: html

    - :ref:`gdalmdiminfo`: Reports structure and content of a multidimensional dataset.
    - :ref:`gdalmdimtranslate`: Converts multidimensional data between different formats, and perform subsetting.

Vector programs
+++++++++++++++

.. toctree::
   :maxdepth: 1
   :hidden:

   Common options <vector_common_options>
   ogrinfo
   ogr2ogr
   ogrtindex
   ogrlineref
   ogrmerge
   ogr_layer_algebra

.. only:: html

    - :ref:`Common options <vector_common_options>`
    - :ref:`ogrinfo`: Lists information about an OGR-supported data source.
    - :ref:`ogr2ogr`: Converts simple features data between file formats.
    - :ref:`ogrtindex`: Creates a tileindex.
    - :ref:`ogrlineref`: Create linear reference and provide some calculations using it.
    - :ref:`ogrmerge`: Merge several vector datasets into a single one.
    - :ref:`ogr_layer_algebra`: Performs various Vector layer algebraic operations.

Geographic network programs
+++++++++++++++++++++++++++

.. toctree::
   :maxdepth: 1
   :hidden:

   gnmmanage
   gnmanalyse

.. only:: html

    - :ref:`gnmmanage`: Manages networks
    - :ref:`gnmanalyse`: Analyses networks

Other utilities
+++++++++++++++

.. toctree::
   :maxdepth: 1
   :hidden:

   sozip

.. only:: html

    - :ref:`sozip`: Generate a seek-optimized ZIP (SOZip) file
