HOWTO import SRTM elevation data: Difference between revisions

From GRASS-Wiki
Jump to navigation Jump to search
(new)
 
 
(24 intermediate revisions by 6 users not shown)
Line 1: Line 1:
Background: [http://www2.jpl.nasa.gov/srtm/ Space Shuttle Radar Topography Mission]
Background: [http://www2.jpl.nasa.gov/srtm/ Space Shuttle Radar Topography Mission]
== Available data ==
[http://www2.jpl.nasa.gov/srtm/ Space Shuttle Radar Topography Mission] - several SRTM Data Versions and Products are available. An overview of the different versions is given in figure 2 in the [https://lpdaac.usgs.gov/sites/default/files/public/measures/docs/NASA_SRTM_V3.pdf SRTM user guide].
* JPL/NASA Version 1 - SRTM non-void filled, unedited elevation data (US: 1 arc-second (approximately 30 meters); global at 3 arc-seconds (approximately 90 meters)). Available at [https://dds.cr.usgs.gov/srtm/version1/ https://dds.cr.usgs.gov/srtm/version1/].
* [https://lta.cr.usgs.gov/SRTM NGA Version 2 - SRTM non-void filled], edited elevation data (spike and pit removal, water body leveling, and coastline definition). Available in the USGS long-term archive through the [http://earthexplorer.usgs.gov/ EarthExplorer].
* [https://lta.cr.usgs.gov/SRTMVF NGA Version 2 - SRTM partially void filled]. Available at 1 and 3 arc-seconds resolution in the USGS long-term archive through the [http://earthexplorer.usgs.gov/ EarthExplorer].
* [https://dds.cr.usgs.gov/srtm/version2_1/ JPL/NASA Version 2.1] (non-void-filled) corrects some minor errors found in the NGA SRTM Version 2 product. Available for the US at [https://dds.cr.usgs.gov/srtm/version2_1/SRTM1/ 1 arc-second] (approximately 30 meters) and global at [https://dds.cr.usgs.gov/srtm/version2_1/SRTM3/ 3 arc-seconds] (approximately 90 meters).
* '''JPL/NASA Version 3 SRTM global elevation data''' provide '''global coverage of completely void filled''' data at resolutions of [https://lpdaac.usgs.gov/dataset_discovery/measures/measures_products_table/srtmgl3_v003 3 arc-seconds] (approximately 90 meters) and [https://lpdaac.usgs.gov/dataset_discovery/measures/measures_products_table/srtmgl1_v003 1 arc-second] (approximately30 meters). The corresponding [https://lpdaac.usgs.gov/dataset_discovery/measures/measures_products_table/srtmswbd_v003 water body data] have also been updated.
SRTM data available through the [http://earthexplorer.usgs.gov/ USGS EarthExplorer] are NGA SRTM version 2. If in doubt, use [https://lpdaac.usgs.gov/dataset_discovery/measures/measures_products_table JPL/NASA Version 3 SRTM global elevation data].
== Download ==
* Older SRTM: http://www2.jpl.nasa.gov/srtm/ (SRTM V1 + SRTM V2 home page) |  http://dds.cr.usgs.gov/srtm/ (JPL/NASA SRTM V1 + V2.1 data download)
* https://lpdaac.usgs.gov/dataset_discovery/measures/measures_products_table NASA MEaSUREs Products (SRTM V3 and more)
: ([http://e4ftl01.cr.usgs.gov/SRTM/SRTMGL1.003/2000.02.11/ 1 arc-second] and [http://e4ftl01.cr.usgs.gov/SRTM/SRTMGL3.003/2000.02.11/ 3 arc-seconds] which are a huge file lists)
Note:
GRASS GIS installations usually contain a location 'demolocation' which is in Latitude-Longitude, suitable for SRTM import.
== Which SRTM tile to take? ==
SRTM tiles are of 1 degree by 1 degree size. The SRTM filename contains the coordinates which refer to the center of the lower left pixel (e.g., N51E010: lower left cell center at 10E, 51N). To identify a tile name, a grid can be easily visualized in the GRASS monitor:
<source lang="bash">
d.grid size=1
</source>


== Import of original SRTM tiles in HGT format ==
== Import of original SRTM tiles in HGT format ==


* see module {{cmd|r.in.srtm}}, import into a Latitude-Longitude location.
 
=== Importing multiple SRTM files via GUI menu ===
 
You can easily import many SRTM files in one step:
<center>
{|
|
[[Image:WxGUI bulk raster import1.png|400px|thumb|Bulk import of SRTM via menu]]
||
[[Image:WxGUI bulk srtm import.jpg|300px|thumb|Bulk import of SRTM via menu (remember to add 'hgt' into the extension field)]]
|
|}
</center>
 
This menu function calls internally the [http://www.gdal.org/frmt_various.html#SRTMHGT SRTM driver of GDAL].
 
=== Importing multiple SRTM files via command line ===
 
Use the {{cmd|r.in.srtm}} module for automated import into a Latitude-Longitude location.
 
See:
* M.H. Bowman. ''Mapping freely available high resolution global elevation and vector data in GRASS.'' GRASS Newsletter, Vol.3, pp 7-10, June 2005. [ [http://grass.osgeo.org/newsletter/GRASSNews_vol3.pdf PDF] ]


== Import of CGIAR SRTM void-filled tiles ==
== Import of CGIAR SRTM void-filled tiles ==
CGIAR SRTM is a heavily edited version of the original SRTM data. Differences to the original SRTM data can be substantial.


* SRTM 90 data in GeoTIFF format are available from http://srtm.csi.cgiar.org/. These come in 5 degree by 5 degree tiles. Horizontal resolution: 3 arc second (90 m at equator). Coverage: world. Import with {{cmd|r.in.gdal}}
* SRTM 90 data in GeoTIFF format are available from http://srtm.csi.cgiar.org/. These come in 5 degree by 5 degree tiles. Horizontal resolution: 3 arc second (90 m at equator). Coverage: world. Import with {{cmd|r.in.gdal}}


== Import of multiple SRTM tiles in one step ==
Update: note that [https://lpdaac.usgs.gov/dataset_discovery/measures/measures_products_table JPL/NASA] (see on top of this page) offers global 1 arc-second resolution SRTM V3 data which are void filled.
 
== Import of multiple SRTM tiles in one step (mosaiking) ==


To simplify the import of multiple SRTM tiles, the tiles can be mosaicked first with gdalwarp:
To simplify the import of multiple SRTM tiles, the tiles can be mosaicked first with gdalwarp:


Original SRTM tiles:
Original SRTM tiles:
<source lang=bash>
  # unzip all
  # unzip all
  for i in *.hgt.zip ; do unzip  $i ; done
  for i in *.hgt.zip ; do unzip  $i ; done
Line 20: Line 74:
  # import
  # import
  r.in.gdal input=srtm_mosaik output=srtm_mosaik
  r.in.gdal input=srtm_mosaik output=srtm_mosaik
 
</source>
CGIAR SRTM tiles:
CGIAR SRTM tiles:
<source lang=bash>
  # create mosaik (optionally reproject on the fly with -t_srs)
  # create mosaik (optionally reproject on the fly with -t_srs)
  gdalwarp *.tif srtm_mosaik.tif
  gdalwarp *.tif srtm_mosaik.tif
  # import
  # import
  r.in.gdal input=srtm_mosaik output=srtm_mosaik
  r.in.gdal input=srtm_mosaik output=srtm_mosaik
</source>


== Void filling of original SRTM tiles ==
== Void filling of original SRTM tiles ==
Line 32: Line 88:


See:
See:
* M. Neteler, 2005. SRTM and VMAP0 data in OGR and GRASS. GRASS Newsletter, Vol.3, pp 2-6, June 2005. [ [http://grass.itc.it/newsletter/GRASSNews_vol3.pdf PDF] | [http://grass.itc.it/newsletter/GRASSNews_vol3_erratum.txt Erratum 1/2006 (txt)] ]  
* M. Neteler, 2005. ''SRTM and VMAP0 data in OGR and GRASS.'' GRASS Newsletter, Vol.3, pp 2-6, June 2005. [ [http://grass.osgeo.org/newsletter/GRASSNews_vol3.pdf PDF] | [http://grass.osgeo.org/newsletter/GRASSNews_vol3_erratum.txt Erratum 1/2006 (txt)] ]
 
''Update 2014'': better use the already void filled SRTM V3 1 arc-second for global coverage (~30 meters) data (get from NASA EarthExplorer, see above)
 
== Import of SRTM tiles with reprojection on the fly ==
 
Instead of processing SRTM in a different location, it can be imported right away into the location of interest (e.g. UTM or whatever other projection) through reprojecting on the fly with bilinear resampling using {{cmd|r.import}}.
 
Example for North Carolina sample dataset with newest 1 arc-second for global coverage (~30 meters). You get the SRTM V3 1 arc-second global data from EarthExplorer (http://earthexplorer.usgs.gov/). The collections are located under the Digital Elevation category.
 
<source lang="bash">
# set computational region to e.g. Landsat channel 3:
g.region raster=lsat7_2000_30 -p
 
# Import with reprojection on the fly. Recommended parameters:
# resample  Resampling method to use for reprojection -  bilinear
# extent  Output raster map extent
#    - region: extent of current region
# resolution  Resolution of output raster map
#    - region: current region resolution - limit to g.region setting from above
r.import input=n35_w079_1arc_v3.tif output=srtmv3_resamp resample=bilinear \
  extent=region resolution=region title="SRTM V3 resampled to Landsat7 resolution"
 
# beautify colors:
r.colors srtmv3_resamp color=elevation
</source>


== See also ==
== See also ==


* [http://en.wikipedia.org/wiki/Shuttle_Radar_Topography_Mission SRTM] in Wikipedia
* [http://en.wikipedia.org/wiki/Shuttle_Radar_Topography_Mission SRTM] in Wikipedia


[[Category:Documentation]]
[[Category:Documentation]]
[[Category:FAQ]]
[[Category:FAQ]]
[[Category:Geodata]]
[[Category: Import]]
[[Category:Raster]]
[[Category:HowTo]]

Latest revision as of 21:46, 24 September 2017

Background: Space Shuttle Radar Topography Mission

Available data

Space Shuttle Radar Topography Mission - several SRTM Data Versions and Products are available. An overview of the different versions is given in figure 2 in the SRTM user guide.

SRTM data available through the USGS EarthExplorer are NGA SRTM version 2. If in doubt, use JPL/NASA Version 3 SRTM global elevation data.

Download

(1 arc-second and 3 arc-seconds which are a huge file lists)

Note: GRASS GIS installations usually contain a location 'demolocation' which is in Latitude-Longitude, suitable for SRTM import.

Which SRTM tile to take?

SRTM tiles are of 1 degree by 1 degree size. The SRTM filename contains the coordinates which refer to the center of the lower left pixel (e.g., N51E010: lower left cell center at 10E, 51N). To identify a tile name, a grid can be easily visualized in the GRASS monitor:

d.grid size=1

Import of original SRTM tiles in HGT format

Importing multiple SRTM files via GUI menu

You can easily import many SRTM files in one step:

Bulk import of SRTM via menu
Bulk import of SRTM via menu (remember to add 'hgt' into the extension field)

This menu function calls internally the SRTM driver of GDAL.

Importing multiple SRTM files via command line

Use the r.in.srtm module for automated import into a Latitude-Longitude location.

See:

  • M.H. Bowman. Mapping freely available high resolution global elevation and vector data in GRASS. GRASS Newsletter, Vol.3, pp 7-10, June 2005. [ PDF ]

Import of CGIAR SRTM void-filled tiles

CGIAR SRTM is a heavily edited version of the original SRTM data. Differences to the original SRTM data can be substantial.

  • SRTM 90 data in GeoTIFF format are available from http://srtm.csi.cgiar.org/. These come in 5 degree by 5 degree tiles. Horizontal resolution: 3 arc second (90 m at equator). Coverage: world. Import with r.in.gdal

Update: note that JPL/NASA (see on top of this page) offers global 1 arc-second resolution SRTM V3 data which are void filled.

Import of multiple SRTM tiles in one step (mosaiking)

To simplify the import of multiple SRTM tiles, the tiles can be mosaicked first with gdalwarp:

Original SRTM tiles:

 # unzip all
 for i in *.hgt.zip ; do unzip  $i ; done
 # create mosaik (optionally reproject on the fly with -t_srs)
 gdalwarp *.hgt srtm_mosaik.tif
 # import
 r.in.gdal input=srtm_mosaik output=srtm_mosaik

CGIAR SRTM tiles:

 # create mosaik (optionally reproject on the fly with -t_srs)
 gdalwarp *.tif srtm_mosaik.tif
 # import
 r.in.gdal input=srtm_mosaik output=srtm_mosaik

Void filling of original SRTM tiles

The module r.fillnulls can be used. See screenshot

See:

  • M. Neteler, 2005. SRTM and VMAP0 data in OGR and GRASS. GRASS Newsletter, Vol.3, pp 2-6, June 2005. [ PDF | Erratum 1/2006 (txt) ]

Update 2014: better use the already void filled SRTM V3 1 arc-second for global coverage (~30 meters) data (get from NASA EarthExplorer, see above)

Import of SRTM tiles with reprojection on the fly

Instead of processing SRTM in a different location, it can be imported right away into the location of interest (e.g. UTM or whatever other projection) through reprojecting on the fly with bilinear resampling using r.import.

Example for North Carolina sample dataset with newest 1 arc-second for global coverage (~30 meters). You get the SRTM V3 1 arc-second global data from EarthExplorer (http://earthexplorer.usgs.gov/). The collections are located under the Digital Elevation category.

# set computational region to e.g. Landsat channel 3:
g.region raster=lsat7_2000_30 -p

# Import with reprojection on the fly. Recommended parameters:
# resample   Resampling method to use for reprojection -  bilinear
# extent   Output raster map extent
#    - region: extent of current region
# resolution   Resolution of output raster map
#    - region: current region resolution - limit to g.region setting from above
r.import input=n35_w079_1arc_v3.tif output=srtmv3_resamp resample=bilinear \
  extent=region resolution=region title="SRTM V3 resampled to Landsat7 resolution"

# beautify colors:
r.colors srtmv3_resamp color=elevation

See also