data:image/s3,"s3://crabby-images/58d15/58d15edfb903a764f22cae6ed49a17f151fe9324" alt=""
Working together
for a safer world
Maximising value from legacy raster bathymetry datasets
data:image/s3,"s3://crabby-images/6737a/6737aecb0ad46bd40ccd32676391ef203911764f" alt=""
Gareth Grewcock
@ gordy99
Rasters Revealed 2017
21.02.2017
data:image/s3,"s3://crabby-images/d5a53/d5a53b81226d3473e5d9524e771e0434ee6d612c" alt=""
data:image/s3,"s3://crabby-images/8458d/8458d3677fcfe664b4a0680f8aecd5983e7b7a3d" alt=""
Bathymetry = 'submarine topography'
Acquistion = £££'s
data:image/s3,"s3://crabby-images/b6cfa/b6cfa1a69c9aebbb348066e3f890d3e002be3c23" alt=""
marine DTM
data:image/s3,"s3://crabby-images/33891/338914e795af9be66cba30946b408cb4b5a60a8b" alt=""
New Bathymetry Survey @ ~£20,000 per day?
Raster Bathymetry DTM = not fit for engineering purposes
- excessively smoothed and delivered as a 5x5m Grid.
- fairly coarse for shallow bathymetry survey
Key seabed features lost
data:image/s3,"s3://crabby-images/df275/df275c069959408867b1e08245200ca7ad3d6ae1" alt=""
Let's review the raw survey data, does it support a higher resolution DTM?
Why has it been delivered at 5x5m?
data:image/s3,"s3://crabby-images/a4efd/a4efd3fe7c3be63b35a96897230d92fdc3e65cbd" alt=""
Discrepancy of absolute depths = tidal issue
oversmoothed bathymetry surface 5x5m
VORF control
surface 1x1m
Raw data reprocessed
1x1m
The raw data does support 1x1m
If we can fix the tidal issue =
130 NW - SE reprocessed lines
30 NE - SW run lines
30 VORF control lines X 130 reprocessed lines = 3600 tidal correction points
5x5m Oversmoothed DTM
VORF control DTM 1x1m
data:image/s3,"s3://crabby-images/324ff/324ff4b59101ada19508a271f8916f2dfc5ded2a" alt=""
30 Tidal Control Points per reprocessed survey line
data:image/s3,"s3://crabby-images/cac11/cac11464f36258a9d2990bd8fe7aacaa8224d22a" alt=""
intersections
calculate the mean difference at each intersection
We can create a raster correction surface using the tidal correction points (mean differences) to level each 1x1m reprocessed survey line to a common level
data:image/s3,"s3://crabby-images/a3b64/a3b64ca126cdf13724b47bbee265114b797d3f31" alt=""
Effectively, we're dealing with XYZ data
Finally - lets talk raster processing...
data:image/s3,"s3://crabby-images/8d8fc/8d8fcc29975935cfde88921d73ff71f37cc95c1e" alt=""
manual reptitive task = automated solution
{Code Snippets}
How did we create the tidal correction raster surface?
data:image/s3,"s3://crabby-images/9465a/9465ad6b6b30eeb502fb94555f79f20add2f8822" alt=""
data:image/s3,"s3://crabby-images/64275/64275f60d97c40c9755591896626e6014eeacd0a" alt=""
automated workflow
task #1
syntax
grdmath rstr-a.tif rstr-b.tif SUB = output.tif=gd:GTiff
Difference each (130) reprocessed 1x1m survey line from the VORF control surface
VORF Control Lines (1 DTM)
Reprocessed 1x1m survey line
task #2
output from task #1
gdalwarp -cutline output.shp -csql "SELECT * FROM output WHERE ID = '29'" -crop_to_cutline out-clip.tif
data:image/s3,"s3://crabby-images/88396/8839683ae5e269d49096270d4de3a8016686585e" alt=""
syntax
Create vector extent for each NE-SW VORF control survey line
grdmath rstr-a.tif=gd:GTiff -10000 GT = output.tif=gd:GTiff
gdal_polygonize output.tif -f "ESRI Shapefile" output.shp
Clip the difference output by each (30) NE-SW VORF control survey line
automated workflow
task #3
output from task #2
data:image/s3,"s3://crabby-images/9d092/9d092e6d2b99e03887ea38505d58b63f7d77e8af" alt=""
100 m
100 m
from osgeo import gdal
clip_out = r"F:\Temp\clip-out.tif"
src_ds = gdal.Open(clip_out)
if src_ds is None:
<font></font>
print 'Unable to open INPUT.tif'
<font></font>
sys.exit(1)
srcband = src_ds.GetRasterBand(1)
stats = srcband.GetStatistics( True, True )
x, y
GDAL Windows Python Bindings | http://www.gisinternals.com/release.php
Calculate the tidal correction offset value
DTM centre coordinates
- min Z value
- max Z value
- mean Z value
- standard deviation
data:image/s3,"s3://crabby-images/9d092/9d092e6d2b99e03887ea38505d58b63f7d77e8af" alt=""
automated workflow
Mean value
(tidal correction offset)
Pipe out to next stage..
automated workflow
Calculate the tidal correction offset value
30 Tidal Correction Offsets for 1x1m reprocessed survey line
data:image/s3,"s3://crabby-images/ff8d6/ff8d6742efb0263d496a4af56452988145e6ab9a" alt=""
data:image/s3,"s3://crabby-images/9904c/9904c25afdaefcd048d2555dd879e8bb9723edcb" alt=""
task #4
arcpy.NaturalNeighbor_3d(mean_tidal_3d_shp_out,"POINT_Z",tidal_correction_surface_out, 1)
natural neighbour interpolation
syntax
calculate offset points (copy parallel)
Create the raster tidal correction offset surface
ArcPy
data:image/s3,"s3://crabby-images/e1a21/e1a21530051dbd57fd17783434f112c3147fbc5f" alt=""
#confession
automated workflow
data:image/s3,"s3://crabby-images/b32f1/b32f1948dbde956dda18a96ca057557ce9d0451b" alt=""
data:image/s3,"s3://crabby-images/9904c/9904c25afdaefcd048d2555dd879e8bb9723edcb" alt=""
data:image/s3,"s3://crabby-images/71f4a/71f4af2a689e9e44995c58bff93ba9a1a0085c67" alt=""
task #5
grdmath rstr-a.tif rstr-b.tif ADD = output.tif=gd:GTiff
data:image/s3,"s3://crabby-images/88d29/88d2973aa8c85069b920a33614f14bf1f90aac3b" alt=""
Level raw legacy survey line with the tidal correction raster surface
automated workflow
Reprocessed 1x1m survey line
Tidal correction raster surface
=
A tidally corrected, 1x1m levelled survey line
task #6
gdalbuildvrt levelled-rasters.vrt *.tif
gdal_translate -co COMPRESS=LZW -a_srs EPSG:32631 levelled-rasters.vrt output-mosaic_1x1m.tif
Create final 1x1m levelled raster DTM surface
directory of 130 levelled survey lines
data:image/s3,"s3://crabby-images/c7a4e/c7a4e6fd15a2bc2d72aaf855a0b497559e445f86" alt=""
automated workflow
- Levelled all 130 1x1m reprocessed survey lines
- 1x1m DTM - now fit for engineering purposes
- Seabed features now clearly identified
results
data:image/s3,"s3://crabby-images/6809b/6809b9d8403140f55ba426c9f412bc8ccd27bfd6" alt=""
data:image/s3,"s3://crabby-images/75cd7/75cd712d6e1dcf9ddc6bf1910a5e8cb1e1f34fa2" alt=""
Ultimately - raster processing saved the client $$$'s!!
data:image/s3,"s3://crabby-images/d1807/d1807964444488ae6f572a76af9a38c906285e79" alt=""
data:image/s3,"s3://crabby-images/58d15/58d15edfb903a764f22cae6ed49a17f151fe9324" alt=""
Working together
for a safer world
Gareth Grewcock
Geospatial Team
Survey & GeoEngineering
Lloyd's Register
T +44 (0)1225 485800 E
Lloyd’s Register and variants of it are trading names of Lloyd’s Register Group Limited, its subsidiaries and affiliates.
Copyright © Lloyd’s Register. 2016. A member of the Lloyd’s Register group.
data:image/s3,"s3://crabby-images/044a5/044a53d9bcc6999c70262743ebfc1606ec89102c" alt=""
Gareth.Grewcock@lr.org
Maximising value from legacy raster bathymetry datasets [Rasters Revealed 2017]
By Lloyd's Register
Maximising value from legacy raster bathymetry datasets [Rasters Revealed 2017]
Presentation to Rasters Revealed 21.02.2017
- 2,236