Skip to content

Instantly share code, notes, and snippets.

@RutgerK
Last active May 9, 2017 08:48
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save RutgerK/47412685882ed3f518c70fd09f57691c to your computer and use it in GitHub Desktop.
Save RutgerK/47412685882ed3f518c70fd09f57691c to your computer and use it in GitHub Desktop.
GDAL Rasterize empty polygon
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "code",
"execution_count": 1,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"'2010300'"
]
},
"execution_count": 1,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"import ogr\n",
"import gdal\n",
"import numpy as np\n",
"\n",
"gdal.VersionInfo()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## WKT"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(True, '{ \"type\": \"MultiPolygon\", \"coordinates\": [ ] }')"
]
},
"execution_count": 2,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# works fine\n",
"geom = ogr.CreateGeometryFromWkt('MULTIPOLYGON EMPTY')\n",
"geom.IsEmpty(), geom.ExportToJson()"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(True, '{ \"type\": \"MultiPolygon\", \"coordinates\": [ ] }')"
]
},
"execution_count": 3,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# works fine\n",
"geom = ogr.CreateGeometryFromWkt('MULTIPOLYGON Z EMPTY')\n",
"geom.IsEmpty(), geom.ExportToJson()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## GeoJSON"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(True, 'MULTIPOLYGON EMPTY')"
]
},
"execution_count": 4,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# works fine,\n",
"geom = ogr.CreateGeometryFromJson('{\"type\": \"MultiPolygon\", \"coordinates\": []}')\n",
"geom.IsEmpty(), geom.ExportToIsoWkt()"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(True, 'MULTIPOLYGON EMPTY')"
]
},
"execution_count": 5,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# works fine,\n",
"geom = ogr.CreateGeometryFromJson('{\"type\": \"MultiPolygon\", \"coordinates\": [[]]}')\n",
"geom.IsEmpty(), geom.ExportToIsoWkt()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### PostGIS ST_ASGEOJSON() output on \"Multipolygon Z EMPTY\" geometry:"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(False, 'MULTIPOLYGON EMPTY')"
]
},
"execution_count": 6,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# this geojson is created when using \"ST_ASGEOJSON(geom)\" in PostGIS\n",
"# on a geometry containing a Z dimensions.\n",
"# Exporting results in empty WKT, but the IsEmpty() check fails\n",
"\n",
"# Using ST_FORCE2D() is a workaround if the Z dimension can be ignored, results in single brackets []\n",
"\n",
"geom = ogr.CreateGeometryFromJson('{\"type\": \"MultiPolygon\", \"coordinates\": [[[]]]}')\n",
"geom.IsEmpty(), geom.ExportToIsoWkt()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Rasterizing an empty geom"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0"
]
},
"execution_count": 7,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"rasdrv = gdal.GetDriverByName('MEM')\n",
"vecdrv = ogr.GetDriverByName('Memory')\n",
"\n",
"# in-mem raster to rasterize to\n",
"outds = rasdrv.Create('', 100, 100, 1, gdal.GDT_Byte)\n",
"outds.SetGeoTransform([0, 1, 0, 0, 0, 1])"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0"
]
},
"execution_count": 8,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# Hard crash\n",
"geom = ogr.CreateGeometryFromJson('{\"type\": \"MultiPolygon\", \"coordinates\": [[[]]]}')\n",
"\n",
"# Works fine\n",
"#geom = ogr.CreateGeometryFromJson('{\"type\": \"MultiPolygon\", \"coordinates\": [[]]}')\n",
"\n",
"# create in-mem vector to rasterize from\n",
"ft = ogr.Feature(ogr.FeatureDefn())\n",
"ft.SetGeometry(geom)\n",
"\n",
"dsvec = vecdrv.CreateDataSource('')\n",
"\n",
"lyr = dsvec.CreateLayer('', None, ogr.wkbMultiPolygon)\n",
"lyr.CreateFeature(ft)"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"# rasterization\n",
"gdal.RasterizeLayer(outds, [1], lyr, burn_values=[1], options=[]) "
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"mask = outds.ReadAsArray()\n",
"mask.min(), mask.max() # expect all zeros for an empty polygon, makes sense"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### gdal.RasterizeLayer() with [[[]]] geojson results in:"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<img src=\"\">"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.6.1"
}
},
"nbformat": 4,
"nbformat_minor": 2
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment